# Tesina di Architettura dei Sistemi di Elaborazione Gruppo 4

Milo Saverio - Mat. M<br/>63/0773 — Pommella Michele - Mat. M<br/>63/0790 — Trimaldi Davide - Mat. M<br/>63/0799

 $31~{\rm gennaio}~2018$ 

## Indice

| 1 | Min  | imizzazione reti combinatorie                           | 1      |
|---|------|---------------------------------------------------------|--------|
|   | 1.1  | Traccia                                                 | <br>1  |
|   | 1.2  | Soluzione                                               | <br>1  |
|   |      | 1.2.1 Minimizzazione 1                                  | <br>1  |
|   |      | 1.2.2 Minimizzazione 2                                  | <br>2  |
|   |      | 1.2.3 Minimizzazione 3                                  | <br>4  |
|   |      | 1.2.4 Minimizzazione 4                                  | <br>5  |
| 2 | Ret  | combinatorie con l'ausilio di SIS e Mapping Tecnologico | 10     |
|   | 2.1  | Traccia                                                 | <br>10 |
|   | 2.2  | Soluzione                                               | <br>10 |
|   |      | 2.2.1 Descrizione in file blif                          | <br>10 |
|   |      | 2.2.2 Esercizio 1                                       | <br>14 |
|   |      | 2.2.3 Esercizio 2                                       | <br>15 |
|   |      | 2.2.4 Esercizio 4                                       | <br>17 |
| 3 | Late | ${ m eh/Flip}$ Flop                                     | 19     |
|   | 3.1  | Traccia                                                 | <br>19 |
|   | 3.2  | Latch RS                                                | <br>19 |
|   |      | 3.2.1 Schematico                                        | <br>19 |
|   |      | 3.2.2 Codice                                            |        |
|   |      | 3.2.2.1 RS Latch                                        |        |
|   |      | 3.2.3 Simulazione                                       |        |
|   |      | 3.2.3.1 Behavioral                                      |        |
|   |      | 3.2.3.2 Post-Sintesi                                    |        |
|   | 3.3  | Latch RS abilitato                                      | <br>21 |
|   |      | 3.3.1 Schematico                                        | <br>21 |
|   |      | 3.3.2 Codice                                            | <br>21 |
|   |      | 3.3.2.1 RS_Latch_Clocked                                |        |
|   |      | 3.3.3 Simulazione                                       | <br>21 |
|   |      | 3.3.3.1 Behavioral                                      | <br>21 |
|   |      | 3.3.3.2 Post-Sintesi                                    | <br>22 |
|   | 3.4  | Latch D abilitato                                       | <br>23 |
|   |      | 3.4.1 Schematico                                        | <br>23 |
|   |      | 3.4.2 Codice                                            | <br>23 |
|   |      | 3.4.2.1 D_Latch_Clocked                                 |        |

|   |      | 3.4.3  | Simulazione                            | 23              |
|---|------|--------|----------------------------------------|-----------------|
|   |      |        | 3.4.3.1 Behavioral                     | 23              |
|   |      |        | 3.4.3.2 Post-Sintesi                   | 24              |
|   | 3.5  | Latch  | Т                                      | 24              |
|   |      | 3.5.1  | Schematico                             | 24              |
|   |      | 3.5.2  | Codice                                 | 24              |
|   |      |        | 3.5.2.1 T_Latch                        | 24              |
|   |      | 3.5.3  | Simulazione                            | 25              |
|   |      |        | 3.5.3.1 Behavioral                     | 25              |
|   |      |        | 3.5.3.2 Post-Sintesi                   |                 |
|   | 3.6  | Latch  | JK abilitato                           |                 |
|   | 0.0  | 3.6.1  | Schematico                             |                 |
|   |      | 3.6.2  | Codice                                 |                 |
|   |      | 0.0.2  | 3.6.2.1 JK Latch Clocked               |                 |
|   |      | 3.6.3  | Simulazione                            |                 |
|   |      | 5.0.5  | 3.6.3.1 Behavioral                     |                 |
|   |      |        |                                        |                 |
|   | 2.7  | Dl. E  |                                        |                 |
|   | 3.7  | -      | lop D Edge Triggered                   |                 |
|   |      | 3.7.1  | Schematico                             |                 |
|   |      | 3.7.2  | Codice                                 |                 |
|   |      |        | 3.7.2.1 FlipFlop_D_edge                |                 |
|   |      | 3.7.3  | Simulazione                            |                 |
|   |      |        | 3.7.3.1 Behavioral                     |                 |
|   |      |        | 3.7.3.2 Post-Sintesi                   | 29              |
|   | 3.8  | Flip-F | lop RS Master-Slave                    | 29              |
|   |      | 3.8.1  | Schematico                             | 29              |
|   |      | 3.8.2  | Codice                                 | 30              |
|   |      |        | 3.8.2.1 FlipFlop RS MS                 | 30              |
|   |      | 3.8.3  | Simulazione                            |                 |
|   |      |        | 3.8.3.1 Behavioral                     |                 |
|   |      |        | 3.8.3.2 Post-Sintesi                   | 30              |
|   |      |        | 0.0.9.2 1 0.0 pm obj                   | 00              |
| 4 | Disj | play a | 7 segmenti                             | 32              |
|   | 4.1  | Tracci |                                        | 32              |
|   | 4.2  | Soluzi | one                                    | 32              |
|   |      | 4.2.1  | Schematici                             | 32              |
|   |      |        | 4.2.1.1 Display a 7 segmenti           | 32              |
|   |      |        | 4.2.1.2 Struttura di multiplexing 16x4 | $\frac{32}{34}$ |
|   |      | 4.2.2  | Codice                                 | 35              |
|   |      | 4.2.2  |                                        | 35              |
|   |      |        |                                        |                 |
|   |      |        | 4.2.2.2 Anode Manager                  | 36              |
|   |      |        | 4.2.2.3 Cathode Manager                | 37              |
|   |      |        | 4.2.2.4 Cathode_encoder                | 39              |
|   |      |        | 4.2.2.5 Display                        | 44              |
|   | 4.3  | Simula |                                        | 46              |
|   | 4.4  | Sintes | su board FPGA                          | 49              |

| 5  | Clo  | k Generator                 | <b>51</b>  |
|----|------|-----------------------------|------------|
|    | 5.1  | Traccia                     | 51         |
|    | 5.2  | Soluzione                   | 51         |
|    |      | 5.2.1 Schematici            | 51         |
|    |      | 5.2.2 Codice                | 52         |
|    | 5.3  | Simulazione                 | 52         |
|    | 5.4  | Sintesi su board FPGA       | 52         |
| 6  | Sanz | Chain                       | 53         |
| U  | 6.1  |                             | 53         |
|    | 6.2  | Soluzione                   |            |
|    | 0.2  | 6.2.1 Schematici            | 53         |
|    |      | 6.2.2 Codice                |            |
|    |      | 6.2.2.1 Boundary Scan Chain |            |
|    | 6.3  | Simulazione                 |            |
|    | 0.5  |                             | 50         |
| 7  | Fini | se State Machine            | <b>5</b> 8 |
|    | 7.1  |                             | 58         |
|    | 7.2  | Soluzione                   |            |
|    |      | 7.2.1 Schematici            | 58         |
|    |      | 7.2.2 Codice                | 59         |
|    |      | _ 0                         | 59         |
|    | 7.3  | Simulazione                 | 62         |
|    | 7.4  | Sintesi su board FPGA       | 63         |
| 8  | Rip  | ole Carry                   | 67         |
|    | 8.1  | ·                           | 67         |
|    | 8.2  | Soluzione                   | 67         |
|    | J    | 8.2.1 Schematici            | 67         |
|    |      | 8.2.2 Codice                | 68         |
|    | 8.3  | Simulazione                 |            |
|    | 8.4  | Sintesi su board FPGA       | 69         |
|    |      |                             |            |
| 9  |      | y Look Ahead                | <b>70</b>  |
|    | 9.1  |                             | 70         |
|    | 9.2  | Soluzione                   |            |
|    |      | 9.2.1 Schematici            |            |
|    |      |                             | 72         |
|    |      | v                           | 72         |
|    | 9.3  | Simulazione                 | 73         |
|    | 9.4  | Sintesi su board FPGA       | 73         |
| 10 | Car  | y Save                      | 74         |
|    |      | ·                           | 74         |
|    |      |                             | 74         |
|    | _    | 10.2.1 Schematici           |            |
|    |      | 10.2.2 Codice               |            |
|    |      |                             | _          |

|           |                        | 10.2.2.1 Carry Save Cell            | . 75 |
|-----------|------------------------|-------------------------------------|------|
|           | 10.3                   | Simulazione                         | . 76 |
|           | 10.4                   | Sintesi su board FPGA               | . 76 |
|           |                        |                                     |      |
| 11        | Car                    | ry Select                           | 77   |
|           | 11.1                   | Traccia                             | . 77 |
|           | 11.2                   | Soluzione                           | . 77 |
|           |                        | 11.2.1 Schematici                   | . 77 |
|           |                        | 11.2.2 Codice                       | . 79 |
|           | 11.3                   | Simulazione                         | . 79 |
|           | 11.4                   | Sintesi su board FPGA               | . 79 |
|           |                        |                                     |      |
| 12        | Add                    | izionatore a 7 operandi             | 80   |
|           | 12.1                   | Traccia                             | . 80 |
|           | 12.2                   | Soluzione                           | . 80 |
|           |                        | 12.2.1 Schematici                   | . 80 |
|           |                        | 12.2.2 Codice                       | . 81 |
|           | 12.3                   | Simulazione                         | . 81 |
|           | 12.4                   | Sintesi su board FPGA               | . 81 |
|           |                        |                                     |      |
| 13        |                        | tiplicatori                         | 82   |
|           | 13.1                   | Traccia                             | . 82 |
|           |                        | 13.1.1 Moltiplicatore a celle Mac   | . 82 |
|           |                        | 13.1.2 Moltiplicatore di Booth      | . 82 |
|           | 13.2                   | Soluzione                           | . 83 |
|           |                        | 13.2.1 Schematici                   | . 83 |
|           |                        | 13.2.1.1 Moltiplicatore a celle Mac |      |
|           |                        | 13.2.1.2 Moltiplicatore di Booth    |      |
|           |                        | 13.2.2 Codice                       |      |
|           |                        | 13.2.2.1 Moltiplicatore a celle Mac |      |
|           | 13.3                   | Simulazione                         |      |
|           |                        | Sintesi su board FPGA               |      |
|           |                        | 13.4.0.1 Moltiplicatore a celle MAC |      |
|           |                        | 13.4.0.2 Moltiplicatore di Booth    |      |
|           |                        |                                     |      |
| 14        | Divi                   | sori                                | 88   |
|           | 14.1                   | Traccia                             | . 88 |
|           | 14.2                   | Soluzione                           | . 89 |
|           |                        | 14.2.1 Schematici                   | . 89 |
|           |                        | 14.2.2 Codice                       | . 90 |
|           | 14.3                   | Simulazione                         |      |
|           |                        | Sintesi su board FPGA               |      |
|           |                        |                                     | 50   |
| <b>15</b> | $\mathbf{U}\mathbf{A}$ | RT                                  | 91   |
|           | 15.1                   | Traccia                             | . 91 |
|           | 15.2                   | Soluzione                           | . 92 |
|           |                        | 15.2.1 Schematici                   | . 92 |
|           |                        |                                     |      |

|    |      | 15.2.2 Codice           | 3 |
|----|------|-------------------------|---|
|    | 15.3 | Simulazione             | 3 |
|    | GPI  |                         | _ |
|    | 16.1 | Traccia                 | 4 |
|    | 16.2 | Soluzione               | 4 |
|    |      | 16.2.1 Schematico       | 4 |
|    |      | 16.2.1.1 GPIO           | 4 |
|    |      | 16.2.2 Codice           | 5 |
|    |      | 16.2.2.1 Pad            |   |
|    |      | 16.2.2.2 GPIO           |   |
|    | 16.3 | Sintesi su board FPGA   |   |
| 17 | Firn | na digitale             | 6 |
|    | 17.1 | Traccia                 | 6 |
|    | 17.2 | Soluzione               | 6 |
|    |      | 17.2.1 Schematici       |   |
|    |      | 17.2.1.1 Funzione hash  | 7 |
|    |      | 17.2.1.2 Esponenziatore |   |
|    |      | 17.2.2 Codice           |   |
|    | 17.3 | Simulazione             |   |
|    |      | Sintesi su board FPGA   |   |

## Capitolo 1

## Minimizzazione reti combinatorie

## 1.1 Traccia

Minimizzare le funzioni descritte dai seguenti ON-SET e DC-SET.

- 1. ON-SET={0, 2, 4, 8, 10, 11, 15}; DC-SET={7, 14}
- 2. ON-SET={0, 1, 2, 7, 8, 10, 15}; DC-SET={5, 9, 11}
- 3. ON-SET={1, 3, 5, 7, 8, 9, 11, 13, 14, 15}; DC-SET={2, 12}
- 4. Fuzione a più uscite F1, F2, F3, descritte rispettivamente da:
  - (a) ON-SET1= $\{0, 4, 8, 9, 14, 15\}$ ; DC-SET1= $\{1, 2, 5, 7\}$
  - (b) ON-SET2={0, 1, 7, 9, 11, 13}; DC-SET2={4, 12}
  - (c) ON-SET3= $\{7, 9, 10, 11, 15\}$ ; DC-SET3= $\{5, 12\}$

## 1.2 Soluzione

La minimizzazione delle funzioni sarà effettuata attraverso i differenti metodi indicati.

## 1.2.1 Minimizzazione 1

La prima funzione è stata minimizzata attraverso il metodo delle mappe di Karnaugh.

Si può generare la seguente tabella di verità a partire dalla definizione insiemistica:

| X | Y | Z | V | F |
|---|---|---|---|---|
| 0 | 0 | 0 | 0 | 1 |
| 0 | 0 | 0 | 1 | 0 |
| 0 | 0 | 1 | 0 | 1 |
| 0 | 0 | 1 | 1 | 0 |
| 0 | 1 | 0 | 0 | 1 |
| 0 | 1 | 0 | 1 | 0 |
| 0 | 1 | 1 | 0 | 0 |
| 0 | 1 | 1 | 1 | _ |
| 1 | 0 | 0 | 0 | 1 |
| 1 | 0 | 0 | 1 | 0 |
| 1 | 0 | 1 | 0 | 1 |
| 1 | 0 | 1 | 1 | 1 |
| 1 | 1 | 0 | 0 | 0 |
| 1 | 1 | 0 | 1 | 0 |
| 1 | 1 | 1 | 0 | _ |
| 1 | 1 | 1 | 1 | 1 |

| ab | 00 b | 01 | 11 | 10         |
|----|------|----|----|------------|
| 00 | 1    |    |    | 1          |
| 01 | 1    |    | Ī  |            |
| 11 |      |    | 1  | <b>-</b> / |
| 10 | 1    |    | 1  | 1          |

Individuando i sottocubi di area massima e gli implicanti primi essenziali, perveniamo alla funzione minimizzata:

$$F = \neg x \neg z \neg v + \neg y \neg v + xz$$

## 1.2.2 Minimizzazione 2

Al fine di minimizzare questa funzione è stato utilizzato il metodo di Quine Mc Cluskey.

## CAPITOLO 1. MINIMIZZAZIONE RETI COMBINATORIE

Si può generare la seguente tabella di verità a partire dalla definizione insiemistica:

| X | Y | Z | V | F |
|---|---|---|---|---|
| 0 | 0 | 0 | 0 | 1 |
| 0 | 0 | 0 | 1 | 1 |
| 0 | 0 | 1 | 0 | 1 |
| 0 | 0 | 1 | 1 | 0 |
| 0 | 1 | 0 | 0 | 0 |
| 0 | 1 | 0 | 1 | - |
| 0 | 1 | 1 | 0 | 0 |
| 0 | 1 | 1 | 1 | 1 |
| 1 | 0 | 0 | 0 | 1 |
| 1 | 0 | 0 | 1 | - |
| 1 | 0 | 1 | 0 | 1 |
| 1 | 0 | 1 | 1 | _ |
| 1 | 1 | 0 | 0 | 0 |
| 1 | 1 | 0 | 1 | 0 |
| 1 | 1 | 1 | 0 | 0 |
| 1 | 1 | 1 | 1 | 1 |

Seguiamo brevemente le fasi di espansione e copertura del metodo di minimizzazione applicato.

| implicante | X | у | z | V | check    |
|------------|---|---|---|---|----------|
| 0          | 0 | 0 | 0 | 0 | <b>V</b> |
| 1          | 0 | 0 | 0 | 1 | <b>V</b> |
| 2          | 0 | 0 | 1 | 0 | 7/ V     |
| 8          | 1 | 0 | 0 | 0 | <b>√</b> |
| 5          | 0 | 1 | 0 | 1 | <b>√</b> |
| 9          | 1 | 0 | 0 | 1 | ✓ 0      |
| 10         | 1 | 0 | 1 | 0 | ✓        |
| 7          | 0 | 1 | 1 | 1 | ✓        |
| 11         | 1 | 0 | 1 | 1 | 1        |
| 15         | 1 | 1 | 1 | 1 | <b>√</b> |

| implicante | X  | у  | Z   | V  | check    |
|------------|----|----|-----|----|----------|
| 0,1        | 0  | 0  | 0   | 8  | ✓        |
| 0,2        | 0  | 0  | 11. | 0  | 1        |
| 0,8        | 5  | 0  | 0   | 0  | <b>√</b> |
| 1,5        | 0  | -5 | 0   | 1  | a        |
| 1,9        | 4  | 0  | 0   | 1  |          |
| 2,10       | 炶  | 0  | 1   | 0  | <b>\</b> |
| 8,9        | 1  | 0  | 0   | _  | <b>(</b> |
| 8,10       | 13 | 0  | -   | 0  | 1        |
| 5,7        | 0  | 1  | -   | 1/ | b        |
| $9,\!11$   | 1  | 0  | -   | 1/ | 1        |
| 10,11      |    | 0  | 1   | Æ  | V        |
| 7,15       | 닉  | 1  | 1/  | 1  | c        |
| 11,15      | 1  | -  | 1   | 1  | d        |

| implicante | X | у | Z | V | $\operatorname{check}$ |
|------------|---|---|---|---|------------------------|
| 0,1,8,9    | - | 0 | 0 | - | е                      |
| 0,2,8,10   | - | 0 | _ | 0 | f                      |
| 8,9,10,11  | 1 | 0 | - | - | g                      |

Individuati gli implicanti primi al termine della fase di espansione, si prosegue con la fase di copertura.

|   | 0 | 1 | 2 | 7 | 8 | 10 | 15 |
|---|---|---|---|---|---|----|----|
| a |   | X |   |   |   |    |    |
| b |   |   |   | Χ |   |    |    |
| c |   |   |   | Χ |   |    | X  |
| d |   |   |   |   |   |    | X  |
| е | Χ | Χ |   |   | Χ |    |    |
| f | Χ |   | Χ |   | Χ | X  |    |
| g |   |   |   |   | X | X  |    |



Discriminando gli implicanti primi essenziali primari (f) e secondari (c), questi ultimi mediante le regole di dominanza, si ottiene una tabella cliclica non ulteriormente riducibile. Applicando il metodo Branch&Bound in questo caso banale, si prosegue nella scelta dell'implicante e per il completamento della copertura. Questa scelta si basa sul costo in termini di letterali dei due implicanti, che individua e come l'implicante che consente la copertura a costo minimo.



Analogamente, tramite il metodo di Petrick, otteniamo la somma degli implicanti che coprono il mintermine in questione:

$$A + E = 1$$

Tra essi si effettua la medesima scelta dettata dal costo dei letterali. La funzione di uscita, dunque, è pari a:

$$F = c + e + f = yzv + \neg y \neg z + \neg y \neg v$$

## 1.2.3 Minimizzazione 3

Si prosegue nuovamente con metodo Quine Mc Cluskey.

Si può generare la seguente tabella di verità a partire dalla definizione insiemistica:

| X | Y | Z | V | F |
|---|---|---|---|---|
| 0 | 0 | 0 | 0 | 0 |
| 0 | 0 | 0 | 1 | 1 |
| 0 | 0 | 1 | 0 | _ |
| 0 | 0 | 1 | 1 | 1 |
| 0 | 1 | 0 | 0 | 0 |
| 0 | 1 | 0 | 1 | 1 |
| 0 | 1 | 1 | 0 | 0 |
| 0 | 1 | 1 | 1 | 1 |
| 1 | 0 | 0 | 0 | 1 |
| 1 | 0 | 0 | 1 | 1 |
| 1 | 0 | 1 | 0 | 0 |
| 1 | 0 | 1 | 1 | 1 |
| 1 | 1 | 0 | 0 | _ |
| 1 | 1 | 0 | 1 | 1 |
| 1 | 1 | 1 | 0 | 1 |
| 1 | 1 | 1 | 1 | 1 |

Attraverso la minimizzazione riusciamo ad ottenere un insieme di implicanti primi essenziali che coprono totalmente la funzione:

$$F = v + x \neg z + xy$$

## 1.2.4 Minimizzazione 4

Poiché non si ricade più nel caso a singola uscita, si è adottato il metodo di Quine Mc Cluskey per funzioni a più uscite. Esso consente il riuso di implicanti comuni a più funzioni, che non si avrebbe per semplice minimizzazione individuale.

Si può generare la seguente tabella di verità a partire dalla definizione insiemistica:

| X | Y | Z | V | F1 | F2 | F3 |
|---|---|---|---|----|----|----|
| 0 | 0 | 0 | 0 | 1  | 1  | 0  |
| 0 | 0 | 0 | 1 | -  | 1  | 0  |
| 0 | 0 | 1 | 0 | -  | 0  | 0  |
| 0 | 0 | 1 | 1 | 0  | 0  | 0  |
| 0 | 1 | 0 | 0 | 1  | -  | 0  |
| 0 | 1 | 0 | 1 | -  | 0  | _  |
| 0 | 1 | 1 | 0 | 0  | 0  | 0  |
| 0 | 1 | 1 | 1 | -  | 1  | 1  |
| 1 | 0 | 0 | 0 | 1  | 0  | 0  |
| 1 | 0 | 0 | 1 | 1  | 1  | 1  |
| 1 | 0 | 1 | 0 | 0  | 0  | 1  |
| 1 | 0 | 1 | 1 | 0  | 1  | 1  |
| 1 | 1 | 0 | 0 | 0  | -  | _  |
| 1 | 1 | 0 | 1 | 0  | 1  | 0  |
| 1 | 1 | 1 | 0 | 1  | 0  | 0  |
| 1 | 1 | 1 | 1 | 1  | 0  | 1  |

Percorriamo l'applicazione del metodo che, rispetto al caso a singola uscita, presenta l'introduzione della maschera rappresentativa delle funzioni a cui l'implicante fa riferimento.



| implicante | X | у | z | v | F1 | F2 | F3 | check    |
|------------|---|---|---|---|----|----|----|----------|
| 0          | 0 | 0 | 0 | 0 | 1  | 1  | 0  | ✓        |
| 1          | 0 | 0 | 0 | 1 | -  | 1  | 0  | <b>√</b> |
| 2          | 0 | 0 | 1 | 0 | -  | 0  | 0  | <b>√</b> |
| 4          | 0 | 1 | 0 | 0 | 1  | -  | 0  | <b>√</b> |
| 8          | 1 | 0 | 0 | 0 | 1  | 0  | 0  | ✓        |
| 5          | 0 | 1 | 0 | 1 | -  | 0  | -  | <b>√</b> |
| 9          | 1 | 0 | 0 | 1 | 1  | 1  | 1  | a        |
| 10         | 1 | 0 | 1 | 0 | 0  | 0  | 1  | <b>√</b> |
| 12         | 1 | 1 | 0 | 0 | 0  | -  | -  | <b>√</b> |
| 7          | 0 | 1 | 1 | 1 | -  | 1  | 1  | b        |
| 11         | 1 | 0 | 1 | 1 | 0  | 1  | 1  | <b>√</b> |
| 13         | 1 | 1 | 0 | 1 | 0  | 1  | 0  | <b>√</b> |
| 14         | 1 | 1 | 1 | 0 | 1  | 0  | 0  | <b>√</b> |
| 15         | 1 | 1 | 1 | 1 | 1  | 0  | 1  | ✓        |

| implicante | X | у   | Z   | V       | F1   | F2  | F3  | check    |
|------------|---|-----|-----|---------|------|-----|-----|----------|
| 0, 1       | 0 | 0   | 0   | -       | 1    | 1   | 0   | c        |
| 0, 2       | 0 | 0   | -   | 0       | 1    | 0   | 0   | d        |
| 0, 4       | 0 | -   | 0   | 0       | 1    | 1   | 0   | e        |
| 0, 8       | - | 0   | 0   | 0       | 1    | 0   | 0   | <b>√</b> |
| 1, 5       | 0 | -   | 0   | 1       | -    | 0   | 0   | <b>√</b> |
| 1, 9       | - | 0   | 0   | 1       | 1    | 1   | 0   | f        |
| 4, 5       | 0 | 1   | 0   | -       | 1    | 0   | 0   | V        |
| 4, 12      | _ | 1   | 0   | 0       | 0    | (9) | 0   | 1        |
| 8, 9       | 1 | 0   | 0   | -1      | 4    | 0   | 0   | \ \ \    |
| 5, 7       | 0 | 1   | -   | 15      | 1 26 | 0   | 1   | g        |
| 9, 11      | 1 | 0   | -11 | 1       | 0    | 1   | _ 1 | h        |
| 9, 13      | 1 | -   | 0   | 1       | 0    | 1   | 0   | i        |
| 10, 11     | 1 | 0   | 1   | $Q_{i}$ | 0    | 0   | 1   | 1        |
| 12, 13     | 1 | 1   | 0   | 7/      | 0    |     | -0- | m        |
| 7, 15      | - | 1   | 18  | 1       | 1    | 0   | 177 | n        |
| 11, 15     | 1 | - } | 1   | 1       | 0    | 0   |     | 0        |
| 14, 15     | 1 | 1   | 1   | Gi      | 1    | 0_  | 0   | p        |

| implicante | X | у | Z | v  | F1 | F2 | F3 | check |
|------------|---|---|---|----|----|----|----|-------|
| 0, 1, 4, 5 | 0 | - | 0 | Œ. |    | 0  | 0  | q     |
| 0, 1, 8, 9 | - | 0 | 0 | 1  |    | 0  | 0  | r     |

Segue la fase di copertura con gli implicanti primi trovati. Essa viene effettuata con l'obiettivo di minimizzare il costo dei letterali.

|   |   |   | I | 71 |    |    |   |   | I | 72 |    |    |   |   | F3 |    |    | costo |
|---|---|---|---|----|----|----|---|---|---|----|----|----|---|---|----|----|----|-------|
|   | 0 | 4 | 8 | 9  | 14 | 15 | 0 | 1 | 7 | 9  | 11 | 13 | 7 | 9 | 10 | 11 | 15 |       |
| a |   |   |   | X  |    |    |   |   |   | X  |    |    |   | Χ |    |    |    | 4     |
| b |   |   |   |    |    |    |   |   | Χ |    |    |    | X |   |    |    |    | 4     |
| c | X |   |   |    |    |    | X | Χ |   |    |    |    |   |   |    |    |    | 3     |
| d | X |   |   |    |    |    |   |   |   |    |    |    |   |   |    |    |    | 3     |
| e | X | Χ |   |    |    |    | X |   |   |    |    |    |   |   |    |    |    | 3     |
| f |   |   |   | X  |    |    |   | Χ |   | X  |    |    |   |   |    |    |    | 3     |
| g |   |   |   |    |    |    |   |   |   |    |    |    | X |   |    |    |    | 3     |
| h |   |   |   |    |    |    |   |   |   | X  | Χ  |    |   | Χ |    | X  |    | 3     |
| i |   |   |   |    |    |    |   |   |   | X  |    | X  |   |   |    |    |    | 3     |
| l |   |   |   |    |    |    |   |   |   |    |    |    |   |   | X  | X  |    | 3     |
| m |   |   |   |    |    |    |   |   |   |    |    | X  |   |   |    |    |    | 3     |
| n |   |   |   |    |    | X  |   |   |   |    |    |    | X |   |    |    | X  | 3     |
| О |   |   |   |    |    |    |   |   |   |    |    |    |   |   |    | X  | X  | 3     |
| р |   |   |   |    | X  | X  |   |   |   |    |    |    |   |   |    |    |    | 3     |
| q | X | Χ |   |    |    |    |   |   |   |    |    |    |   |   |    |    |    | 2     |
| r | X |   | X | X  |    |    |   |   |   |    |    |    |   |   |    |    |    | 2     |

|   | F1 |   | F2 |     |      | F3  |     | costo |
|---|----|---|----|-----|------|-----|-----|-------|
|   | 4  | 0 | 1  | 13  | 7    | 9   | 15  |       |
| a |    |   |    |     |      | X   |     | 4     |
| b |    |   |    |     | X    |     |     | 1     |
| c |    | X | Х  |     |      |     | Ph. | 3     |
| е | X  | X |    |     |      |     | 16  | 3     |
| f |    |   | Χ  |     | 1    |     | 1   | 3     |
| g |    |   |    |     | X    | 5.1 |     | 3     |
| h |    |   |    |     | 10   | X   |     | ,1    |
| i |    |   |    | X   | 5    | 1   |     | 3     |
| m |    |   |    | X   | 4    | /   | 킞   | 3     |
| n |    |   |    | 110 | X    |     | X   | 3     |
| О |    |   |    |     | 1:18 |     | X   | 3     |
| q | X  |   |    | 17  |      |     |     | 2     |

|   | F1  | F2   |     |     |   | F3 |    | costo |
|---|-----|------|-----|-----|---|----|----|-------|
| 1 | 4   | 0    | 1   | 13  | 7 | 9  | 15 |       |
| b | 1/5 | 100  |     |     | X |    |    | 1     |
| c |     | X    | Χ   |     |   |    |    | 3     |
| e | X   | X    | 16  |     |   |    |    | 3     |
| h |     | 11/2 |     | Ø.  |   | X  |    | 1     |
| i | Λ.  | , 1  | 1   | X   |   |    |    | 3     |
| m | 1 5 | Ľ.   | K   | X   |   |    |    | 3     |
| n |     | - 1  | 1/2 | -31 | X |    | X  | 3     |
| q | X   | 99   | N.  | 94  |   |    |    | 2     |

|   | F1 | F2 | costo |
|---|----|----|-------|
|   | 4  | 13 |       |
| е | X  |    | 3     |
| i |    | X  | 3     |
| m |    | X  | 3     |
| q | X  |    | 2     |

|   | F1   | F2  | costo  |
|---|------|-----|--------|
|   | 4    | 13  | STOP P |
| i | 27   | X   | 3      |
| m | DES. | _X/ | 3      |
| q | X    | JA  | 2      |

| 1/2 | F2 | costo |  |  |
|-----|----|-------|--|--|
|     | 13 |       |  |  |
| i   | X  | 3     |  |  |
| m   | X  | 3     |  |  |

Si arriva ad una tabella ciclica, i cui implicanti presentano anche lo stesso costo. Per la minimizzazione si è scelto i, ottenendo:

$$F1 = r + p + q = \neg y \neg z + xyz + \neg x \neg z$$
 
$$F2 = b + h + c + i = \neg xyzv + x \neg yv + \neg x \neg y \neg z + x \neg zv$$
 
$$F3 = l + n + h = x \neg yz + yzv + x \neg yv$$



## Capitolo 2

## Reti combinatorie con l'ausilio di SIS e Mapping Tecnologico

## 2.1 Traccia

Utilizzare lo strumento automatico SIS per la minimizzazione di circuiti combinatori e il relativo mapping tecnologico.

## 2.2 Soluzione

Si farà riferimento agli esercizi del capitolo 1, definiti in file di formato blif per la minimizzazione ed il mapping tecnologico mediante SIS.

### 2.2.1 Descrizione in file blif

Di seguito verrano elencati i relativi file blif, con i quali è possibili minizzare automaticamente le funzioni sopra descritte.

### CAPITOLO 2. RETI COMBINATORIE CON L'AUSILIO DI SIS E MAPPING TECNOLOGICO

#### In riferimento a 1.2.1

```
.model esercizio1
   .inputs a b c d
2
   .outputs f
3
   .names a b c d f
5
   0000 1
   0010 1
   0100 1
   1000 1
   1010 1
10
   1011 1
11
   1111 1
12
13
   .exdc
14
   .inputs a b c d
15
   .outputs f
16
17
   .names a b c d f
18
   0111 1
19
   1110 1
20
^{21}
   .end
^{22}
```

#### In riferimento a 1.2.2



## CAPITOLO 2. RETI COMBINATORIE CON L'AUSILIO DI SIS E MAPPING TECNOLOGICO

#### In riferimento a 1.2.3

```
.model esercizio3
   .inputs a b c d
   .outputs f
   .names a b c d f
5
   0001 1
6
   0011 1
7
   0101 1
   0111 1
   1000 1
10
   1001 1
11
   1011 1
12
   1101 1
13
   1110 1
14
   1111 1
15
16
   .exdc
17
   .inputs a b c d
18
   .outputs f
19
20
   .names a b c d f
21
   0010 1
^{22}
   1100 1
^{23}
^{24}
   .end
```



#### In riferimento a 1.2.4

```
.model esercizio4
   .inputs a b c d
   .outputs f1 f2 f3
   .names a b c d f1
5
   0000 1
6
   0100 1
7
   1000 1
   1001 1
   1110 1
10
   1111 1
11
12
   .names a b c d f2
13
   0000 1
14
   0001 1
15
   0111 1
16
   1001 1
17
   1011 1
18
   1101 1
19
20
   .names a b c d f3
21
   0111 1
^{22}
   1001 1
^{23}
   1010 1
^{24}
   1011 1
   1111 1
26
27
   .exdc
28
   .inputs a b c d
29
   .outputs f1 f2 f3
30
31
   .names a b c d f1
^{32}
   0001 1
33
   0010 1
34
   0101 1
35
   0111 1
36
^{37}
   .names a b c d f2
38
   0100 1
39
   1100 1
40
41
   .names a b c d f3
42
   0101 1
43
   1100 1
44
45
   .end
46
```

#### 2.2.2 Esercizio 1

La minimizzazione automatica restituisce lo stesso risultato di quella eseguita manualmente attraverso il comando full\_simplify. Effettuando due diversi tipi di mapping, i valori di area e ritardo variano secondo le esigenze esposte.

Ciò è possibile perchè la libreria è fornita di diversi componenti, ma se la riduciamo ad un set funzionalmente completo, **And** e **Not** ad esempio, i risultati non variano.

#### 2.2.3 Esercizio 2

Vogliamo mettere in evidenza in questo esempio come la tecnologia impatta sulle prestazioni di una rete combinatoria.

```
sis> read_blif C:\Users\Saverio\Desktop\ASE\sis\esercizio2.blif
sis> espresso
sis> write_eqn
INORDER = a b c d;
OUTORDER = f;
[920] = !b*!c;
[921] = b*c*d;
[922] = !b*!d;
[923] = ![920]*![921]*![922];
f = ![923];
```

Utilizzando espresso ritroviamo la medesima minimizzazione attuata manualmente col metodo di Quine Mc Cluskey. I costi della rete, in termini di numero di litterali Cl, numero di ingressi Ci, numero di porte Cp, sono Cl = 7; Ci = 10; Cp = 4. Vediamo come si comporta invece la rete con l' utilizzo della libreria menc. Ottimizzando l'area occupata:

```
sis> read_blif C:\Users\Saverio\Desktop\ASE\sis\esercizio2.blif
sis> map -W -n 0 -s
>>> before removing serial inverters <<<
# of outputs: 1
total gate area: 14.00
maximum arrival time: (9.30,9.30)
maximum po slack: (-9.30,-9.30)
minimum po slack: (-9.30,-9.30)
total neg slack: (-9.30,-9.30)
# of failing outputs: 1
>>> before removing parallel inverters <<<
# of outputs: 1
total gate area: 14.00
maximum arrival time: (9.30,9.30)
maximum po slack: (-9.30,-9.30)
minimum po slack: (-9.30,-9.30)
minimum po slack: (-9.30,-9.30)
# of failing outputs: 1
# of outputs: 1
total gate area: 14.00
maximum arrival time: (9.30,9.30)
maximum po slack: (-9.30,-9.30)
# of failing outputs: 1
total gate area: 14.00
maximum po slack: (-9.30,-9.30)
minimum po slack: (-9.30,-9.30)
minimum po slack: (-9.30,-9.30)
minimum po slack: (-9.30,-9.30)
minimum po slack: (-9.30,-9.30)
# of failing outputs: 1
sis> write_eqn
INORDER = a b c d;
OUTORDER = f;
[950] = !a*!b*!c*![975];
[1000] = !c + !b + !d;
[979] = !b*!d + ![1000];
f = [979] + [950];

Don't care:
INORDER = a b c d;
OUTORDER = f;
f = a*!b*!c*d + !a*b*!c*d + a*!b*c*d;
```

In questo caso i costi sono Cl = 9 - Ci = 13 - Cp = 5. I costi aumentano perchè SIS cerca di usare porte che occupano meno spazio, non curandosi dei tempi di commutazione e di propagazione dell'informazione lungo il path critico.

Ottimizzando il ritardo:

```
s1s> map -W -n 1 -s
 of outputs:
                          20.00
total gate
                         (5.00,5.00)
(-5.00,-5.00)
maximum arrival time:
maximum po slack:
minimum po slack:
                         (-5.00, -5.00)
total neˈg slack:
# of failing outputs:
                         (-5.00,-5.00)
sis> write_eqn
INORDER = abcd;
            + ![1058] + ![1056] + ![1063];
             + !b + !c;
1083] = ![1059] + ![1056];
  = ![1083] + ![1079] + ![1077];
Don't care:
INORDER = a b c d;
OUTORDER = f;
 = a*!b*!c*d + !a*b*!c*d + a*!b*c*d;
```

Rilassando il vincolo di area ottieniamo prestazioni vicine a quelle di espresso: Cl = 9; Ci = 12; Cp = 4. Ciò è possibile perchè la libreria ha a disposizione un adeguato numero di componenti da utilizzare, situazione non sempre veritiera.



#### 2.2.4 Esercizio 4

Proviamo ad applicare il rugged-script ad un rete multi-uscita:

```
sis> read_blif "C:\Users\Saverio\Desktop\ASE\Template Elaborato\esercizio01\listing\simulazione\esercizi
o4.blif"
sis> source -x script.rugged
sweep; eliminate -1; simplify -m nocomp; eliminate -1
sweep; eliminate 5; simplify -m nocomp
resub -a;fx; resub -a
sweep; eliminate -1
sweep; full simplify -m nocomp
sis> write_eqn
INORDER = abcd;
OUTORDER = f1 f2 f3;
f1 = a*b*c + !a*![321] + !b*!c;
f2 = d*!f1*f3 + a*!c*d + !a*!b*!c;
f3 = a*!b*[321] + b*c*d;
[321] = d + c;
Don't care:
INORDER = abcd;
OUTORDER = f1 f2 f3;
f1 = !a*!b*c*!d + !a*!b*!c*d + !a*b*!c*d + !a*b*c*d;
f2 = !a*b*!c*!d + a*b*!c*!d;
f3 = a*b*!c*!d + !a*b*!c*d;
sis> print_stats
esercizio4 pi= 4 po= 3 node= 4 latch= 0 lits(sop)= 24 lits(ff)= 23
```

La minimizzazione sub-ottima ottenuta con questo metodo euristico è simile a quella ricavata da Mc Cluskey multi-funzione, a conferma del fatto che il rugged-script si rivela una buona sequenza per le trasformazioni da applicare alla rete. Rimappiamo la nostra rete su un fpga avente componenti elementari a quattro ingressi.

```
sis> xl_imp -n 4
sis> xl cover -n 4
sis> write_eqn
INORDER = a b c d;
OUTORDER = f1 f2 f3;
f1 = !a*!c*!d + a*b*c + !b*!c;
f2 = a*!b*c*d + !a*b*c*d + a*!c*d + !a*!b*!c;
f3 = b*c*d + a*!b*d + a*!b*c;
Don't care:
INORDER = abcd;
OUTORDER = f1 f2 f3;
f1 = !a*!b*c*!d + !a*!b*!c*d + !a*b*!c*d + !a*b*c*d;
f2 = !a*b*!c*!d + a*b*!c*!d;
f3 = a*b*!c*!d + !a*b*!c*d;
sis> print_stats
```

Il mapping è stato possibile perchè il fan-in dei nodi della rete non è maggiore del numero di input di una cella. Al seguito di questa verifica, è stata effettuata la minimizzazione del numero di nodi della rete e l'associazione di questi alle celle Xilinx. Il numero di nodi utilizzati per sintetizzare la rete è diminuito e il numero di letterali è aumentato di 7 unità: un nodo è stato eliminato sostituendo la sua espressione nei nodi a valle. Ciò ha consentito un risparmio di area, in termini

## CAPITOLO 2. RETI COMBINATORIE CON L'AUSILIO DI SIS E MAPPING TECNOLOGICO

di celle, ed eventualmente anche di tempo, grazie ad una dipendenza più diretta dei nodi a valle dagli input primari.



## Capitolo 3

## Latch/Flip Flop

## 3.1 Traccia

Sviluppare i circuiti illustrati nel documento sui flip-flop. Eseguire per ciascun esercizio una simulazione comportamentale e post-sintesi, illustrando i passaggi salienti.

## 3.2 Latch RS

#### 3.2.1 Schematico

Si è scelto di implementare il latch RS in logica 1-attiva con due porte NOR, questo implica che, quando S=1 e R=0, l'uscita Q è alta, che lo stato neutro degli ingressi è S=R=0 e quello non ammesso è S=R=1, il quale, seguito dal passaggio allo stato neutro, produce un'uscita non stabile e soggetta ad un transitorio, che può portare ad alee e quindi a corse. Dualmente, grazie alla simmetria del circuito, è possibile cambiare la logica in 0-attiva utilizzando due porte NAND.

#### **3.2.2** Codice

## 3.2.2.1 RS\_Latch

Questo componente è stato realizzato con un'architettura di tipo Structural, connettendo due componenti *nor\_gate*, che non fanno altro che la NOR dei due ingressi. Le uscite di ogni porta nor viene poi retroazionata all'ingresso dell'altra porta.

Il progetto ISE del componente in questione è osservabile a questo link: RS\_Latch ISE

#### 3.2.3 Simulazione

#### 3.2.3.1 Behavioral

In questo tipo di simulazione, viene modellato solo il comportamento funzionale del sistema, infatti le porte sono considerate ideali e quindi senza ritardo; per questo motivo quando provo ad utilizzare la configurazione degli ingressi non ammessa R=S=1 (che viola il vincolo logico  $R \cdot S=0$  e quindi quello  $Q=not(\neg Q)$ ) e poi nello stesso istante (80 ns) le abbasso entrambe , questo genera degli eventi oscillatori che producono cicli di delta cycle. Questi però non riusciamo ad osservarli in

simulazione poichè il tempo di simulazione non avanza e viene generato un errore che indica che si è raggiunto il limite di iterazioni, dovuto al fatto che il sistema non riesce a raggiungere uno stato stabile. Queste oscillazioni invece sono visibili nella simulazione Post-Map, in cui vengono introdotti i ritardi dei componenti di libreria ma non quelli relativi alle loro connessioni.



Figura 3.1: Simulazione del latch RS Behavioral

#### 3.2.3.2 Post-Sintesi

La simulazione di Figura 3.2 rappresenta l'evoluzione del sistema in seguito all'operazione di Place & Route che, dopo aver utilizzato dei componenti della libreria Xilinx con i relativi ritardi dovuti ai tempi di commutazione, collega tali componenti, tenendo in considerazione i ritardi delle connessioni relative al routing effettuato. Proprio grazie a questi ritardi la simulazione continua e non si blocca come quella precedente quando gli ingressi passano dal valore R=S=1 a R=S=0, ma vengono introdotte delle asimmetrie nel circuito che portano le uscite ad assumere dei valori che rispettano i vincoli logici, nel nostro caso sono Q=1 e  $\neg Q=0$  a 86 ns. Però è importante sottolineare che questi valori prodotti in uscita non sono deterministici, perchè generati da corse e quindi è preferibile non ottenerli rispettando il vincolo che proibisce l'utilizzo di entrambi gli ingressi alti.



Figura 3.2: Simulazione del latch RS Post-Route

## 3.3 Latch RS abilitato

#### 3.3.1 Schematico

Questo tipo di latch deriva dal latch RS precedente, al quale si antepone una rete combinatoria formata da due porte AND, i cui ingressi sono R ed S e in più un segnale di abilitazione, che può essere un clock, ma che in nessun caso rende sincrona la rete.

#### 3.3.2 Codice

## 3.3.2.1 RS\_Latch\_Clocked

Tale componente è stato realizzato con un'architettura Structural, connettendo, tramite i due segnali  $r\_clocked$  ed  $s\_clocked$ , le uscite di due porte AND, realizzate con il componente  $and\_gate$ , agli ingressi R ed S del componente  $rs\_latch$  visto precedentemente (componente RS\_Latch). Ovviamente in ingresso alle porte AND ci saranno i segnali di set e reset, nonché un clock che funge da segnale di abilitazione.

Il progetto ISE del componente in questione è osservabile a questo link: RS\_Latch\_Clocked ISE

#### 3.3.3 Simulazione

#### 3.3.3.1 Behavioral

In Figura 3.3 è rappresentata la simulazione behavioral del latch RS abilitato, che si comporta come un normale latch RS quando il clock è alto, altrimenti mantiene lo stato precedente. Inoltre si osserva, come nel caso del latch RS, che la simulazione si ferma (in questo caso a 50 ns) e viene generato un errore che indica che si è raggiunto il limite di iterazioni. Tutto questo è dovuto al fatto che, avendo utilizzanto nel testbench, a 45 ns, la configurazione degli ingressi non ammessa R=S=1, vengono generate delle oscillazioni non osservabili in questo tipo di simulazione e che

probabilmente sono causate dal successivo abbassamento del segnale di clock alla soglia dei 50 ns, che porterebbe il sistema a conservare lo stato precedente forzando i valori di ingresso R=S=0.



Figura 3.3: Simulazione del latch RS abilitato Behavioral

#### 3.3.3.2 Post-Sintesi

In Figura 3.4 è mostrata la simulazione Post-Route del sistema. Come si è verificato per il lactch RS, anche qui, utilizzando i componenti della libreria Xilinx e considerando i loro ritardi e quelli delle connessioni, si osserva che la simulazione continua e non si arresta, grazie al fatto che vengono forzati dei valori in uscita (Q=1 e  $\neg$ Q=0 a 55ns) dovuti all'asimmetria introdotta dopo l'operazione di Place & Route.



Figura 3.4: Simulazione del latch RS abilitato Post-Route

## 3.4 Latch D abilitato

#### 3.4.1 Schematico

Il latch D abilitato può essere realizzato a partire da un latch RS abilitato i cui ingressi R ed S vengono fatti corrispondere al valore D in ingresso, rispettivamente una volta negato tramite una porta NOT e una volta no. Questo latch permette di avere in uscita Q il valore D in ingresso, ma ritardato di un certo  $\Delta$ .

#### 3.4.2 Codice

### 3.4.2.1 D Latch Clocked

Questo componente è stato creato come un'architettura Structural a partire dal componente  $rs\_latch\_clocked$  visto in precedenza (componente RS\_Latch\_Clocked). L'ingresso D viene collegato all'ingresso S del latch rs abilitato e viene utilizzato un segnale notd per negare D e collegarlo all'ingresso R.

Il progetto ISE del componente in questione è osservabile a questo link: D latch Clocked ISE.

#### 3.4.3 Simulazione

#### 3.4.3.1 Behavioral

Come si nota dalla simulazione behavioral di Figura 3.5 quando D e il clock sono alti il segnale in uscita Q è alto, altrimenti o viene mantenuto lo stato precedente quando il clock è basso oppure quando D è basso e il clock è altro, sarà l'uscita ¬Q ad essere alta. Anche in questo caso come in quelli precedenti, la simulazione si arresta a 40 ns a causa di un errore che indica il raggiungimento del limite di iterazioni dovuto alla generazione di cicli di delta cycle, che non permettono di giungere ad uno stato stabile.



Figura 3.5: Simulazione del latch D abilitato Behavioral

#### 3.4.3.2 Post-Sintesi

In Figura 3.6 è rappresentata la simulazione Post-Route del componente. Grazie all'introduzione dei ritardi dei componenti della libreria Xilinx e a quelli relatvi ai collegamenti tra gli stessi, la simulazione è in grado di continuare senza bloccarsi; ovviamente questo comporta un ritardo nella generazione delle uscite che commutano un po' dopo il sollevamento del segnale di clock. Ad aumentare ulteriormente il ritardo è l'aggiunta della porta NOT, che aumenta ulteriormente il tempo di commutazione rispetto al latch RS abilitato.



Figura 3.6: Simulazione del latch D abilitato Post-Route

## 3.5 Latch T

#### 3.5.1 Schematico

Il latch T può essere realizzato similmente al latch RS abilitato, solo che, in ingresso alle porte AND, vanno le uscite retroazionate al posto degli ingressi di reset e set e il segnale T che, quando è abilitato, non fa altro che commutare l'uscita Q.

#### **3.5.2** Codice

#### 3.5.2.1 T Latch

L'approccio utilizzato per la realizzazione di questo tipo di latch è quello strutturale, in base al quale, a partire dal componente RS\_Latch visto in precedenza, sono state aggiunte due porte AND, in ingresso alle quali vanno il segnale T e le uscite Q e  $\neg Q$  del latch RS retroazionate. Per fare questo sono stati utilizzati quattro segnali: due  $(retro\_q \ e \ retro\_notq)$  utilizzati per le uscite del latch e altri due  $(retro\_q\_delayed)$  e  $retro\_notq\_delayed)$  utilizzati per ritardare, tramite la parola chiave after, tali uscite in modo che possano essere utilizzate in ingresso alle porte AND, questo perchè altrimenti le uscite non riescono a commutare.

Il progetto ISE del componente in questione è osservabile a questo link: T Latch ISE

#### 3.5.3 Simulazione

#### 3.5.3.1 Behavioral

In figura 3.7 si osserva la simulazione Behavioral del latch\_t. Così come si nota quando T è alto possono avvenire una o più commutazione delle uscite in base alla sua durata, infatti T dovrebbe essere alto per un tempo sufficientemente grande affinchè avvenga una commutazione ma sufficientemente piccolo affinchè non ne avvengano altre. Si noti inoltre, che quando T è basso, il sistema mantine lo stato precedente.



Figura 3.7: Simulazione del latch T Behavioral

#### 3.5.3.2 Post-Sintesi

Nella simulazione Post-Sintesi invece, dato che la parola chiave after, usata precedentemente per permettere la commutazione delle uscite, non è sintetizzabile, allora le uscite non cambiano stato e permangono per tutta la durata della simulazione in uno stato "uninitialized".

## 3.6 Latch JK abilitato

#### 3.6.1 Schematico

Il latch JK è strutturato in maniera simile al latch RS abilitato, ciò che cambia è che le porte AND prendono in ingresso le uscite retroazionate, così come avviene per il latch T, il clock e due segnali J e K. In base alla configurazione di questi due segnali cambia il funzionamento del latch, poiché se K=J=1, esso si comporta come un latch T, altrimenti si comporta come un latch RS in cui R=K e S=J.

#### **3.6.2** Codice

## $3.6.2.1 \quad JK\_Latch\_Clocked$

Questo tipo di componente è stato realizzato con un'architettura Structural, in cui si antepongono ad un latch RS (componente RS\_Latch), due porte AND a tre ingressi, cioè il clock, K o J, e una delle due uscite retroazionata. Questo avviene tramite l'utilizzo di quattro segnali, ovvero q\_feedback e notq\_feedback, utilizzati per le uscite del latch RS, e q\_feedback\_delayed e notq\_feedback\_delayed, utilizzati per ritardare tali segnali, in modo che possano essere retroazionati in ingresso alle porte AND e quindi permettere la commutazione. Sono presenti inoltre due ingressi di clear e preset, messi in OR con le uscite delle porte AND, in modo da inizializzare il dispositivo, tramite i segnali in\_latch\_r e in\_latch\_s, messi in ingresso al latch RS. Il progetto ISE del componente in questione è osservabile a questo link: JK Latch ISE

#### 3.6.3 Simulazione

#### 3.6.3.1 Behavioral

In Figura 3.8 è rappresentata la simulazione Behavioral del funzionamento del latch JK abilitato. Si nota che, così come ci aspettiamo, quando J è alto, Q è alto, mentre quando K è alto,  $\neg Q$  è alto; quando invece sia J che K sono alti, il sistema funziona come un latch T e quindi le uscite commutano un certo numero di volte, che dipende dalla durata dello stato J=K=1. Ovviamente quando sia J che K sono bassi oppure il clock è basso, il sistema permane nello stato precedente.



Figura 3.8: Simulazione del latch JK abilitato Behavioral

#### 3.6.3.2 Post-Sintesi

Nella simulazione Post-Route di Figura 3.9 vengono utilizzati i componenti della libreria Xilinx con i relativi ritardi e quelli dovuti ai collegamenti tra gli stessi e quindi notiamo un certo delay nella commutazione delle uscite rispetto al caso Behavioral. Si nota inoltre che in seguito alla

fine della condizione in cui J=K=1, anzichè permanere in uno stato, le uscite commutano sempre, probabilmente a causa di alcune asimmetrie introdotte nel circuito dalla fase di sintesi.



Figura 3.9: Simulazione del latch JK abilitato Post-Route

## 3.7 Flip-Flop D Edge Triggered

#### 3.7.1 Schematico

Un Flip-Flop D Edge Triggered che commuta sul fronte di discesa del clock può essere realizzato, così come si evince dalla Figura 3.10, attraverso 6 porte NOR opportunamente interconnesse. Quando il clock è alto, l'uscita delle porte G2 e G3 viene forzata a 0, quindi il latch 3 mantiene il proprio stato delle uscite e il latch 1 e il latch 2 seguono il valore D e  $\neg$ D rispettivamente. All'atto della transizione del clock dal valore alto a quello basso, i valori di D e  $\neg$ D vengono propagati agli ingressi del latch 3 e quindi in uscita. Considerando  $\tau$  il ritardo di ogni porta, la rete impiega  $5\tau$  per commutare. Si noti inoltre, un ulteriore ingresso alla porta G2, che non è altro che l'uscita della porta G1 retroazionata; questo elemento, può sembrare ridondante, in realtà evita il presentarsi di un'alea che, all'atto della transizione del clock 1->0, causerebbe un valore inatteso all'uscita della porta G2, dovuto al ritardo di  $3\tau$  per propagare l'ingresso R1a, infatti l'uscita della porta G1 ha lo stesso valore dell'uscita della porta G3, solo che è possibile ottenerla con un ritardo pari solo a  $\tau$ .



Figura 3.10: Schematico Flip-Flop D Edge Triggered

#### 3.7.2 Codice

## $3.7.2.1 \quad FlipFlop\_D\_edge$

Il Flip-Flop D Edge Triggered è stato realizzato con un'architettura Structural componendo 6 porte NOR, opportunamente connesse con dei segnali da G1 a G6 che rappresentano le uscite delle omonime porte. Si noti che per settare l'uscita della porta NOR G2, che ha tre ingressi, è stata applicata una porta NOT al risultato dell'OR tra l'uscita della porta G3, il clock e l'uscita della porta G1, utilizzata per eliminare l'alea.

Il progetto ISE del componente in questione è osservabile a questo link: FlipFlop D Edge ISE

#### 3.7.3 Simulazione

#### 3.7.3.1 Behavioral

Nella simulazione Behavioral di Figura 3.11 si osserva il funzionamento del Flip Flop D. Come si nota la commutazione delle uscite avviene in corrispondenza del fronte di discesa del clock in maniera istantanea, non avendo usato a questo livello i componenti della libreria Xilinx.



Figura 3.11: Simulazione del Flip-Flop D Edge Triggered Behavioral

#### 3.7.3.2 Post-Sintesi

In Figura 3.14 è rappresetata una simulazione Post-Route del Flip-Flop D. Come c'era da aspettarsi, tenendo in considerazione i ritardi dei componenti utilizzati e quelli relativi al routing, la commutazione delle uscite non avviene istantanemente rispetto al fronte di discesa del clock, ma con un ritardo che è circa 6 ns, che quindi è in linea con il ritardo di  $5\tau$  predetto precedentemente. Si noti inoltre l'assenza di alee grazie all'aggiunta del collegamento dell'uscita della porta G1 all'ingresso della porta G2.



Figura 3.12: Simulazione del Flip-Flop D Edge Triggered Post-Route

## 3.8 Flip-Flop RS Master-Slave

#### 3.8.1 Schematico

Un Flip-Flop RS Master-Slave viene realizzato collegando in cascata due latch RS abilitati da un segnale di clock nel caso del primo latch (master) è affermato, mentre nel caso del secondo (slave) è negato. Questo comporta che i due latch non funzionano contemporaneamente ma quando uno è attivo l'altro è disattivo e viceversa.

#### **3.8.2** Codice

#### 3.8.2.1 FlipFlop RS MS

Il componente flipflop\_rs\_ms è stato realizzato con un approccio Structural, poichè sono stati utilizzati due componenti rs\_latch\_clocked visti in precedeza (componente RS\_Latch\_Clocked), collegati tramite i due segnali q\_master e notq\_master che vanno in ingresso rispettivamente al set e al reset del latch slave. Infine è stata utilizzata una porta NOT per negare il segnale di clock che è stato poi collegato al secondo latch.

Il componente in questione è osservabile a questo link: FlipFlop RS MS ISE

#### 3.8.3 Simulazione

#### 3.8.3.1 Behavioral

In Figura 3.13 viene mostrata la simulazione Behavioral quindi il funzionamento di questo tipo di circuito. Come si nota, quello che di fatto realizza è un flip-flop RS pilotato sul fronte di discesa del clock, in corrispondeza del quale avviene la commutazione delle uscite Q e ¬Q. In questo caso la simulazione continua fino alla fine poichè non è stata utilizzata la configurazione R=S=1 non ammessa e quindi non si sono generati eventi oscillatori.



Figura 3.13: Simulazione del Flip-Flop RS Master-Slave Behavioral

#### 3.8.3.2 Post-Sintesi

Nella simulazione Post-Route di Figura 3.14, come nei casi precedenti notiamo che la commutazione delle uscite avviene con circa 5-6 ns di ritardo, dovuto all'utilizzo dei componenti della libreria Xilinx e ai ritardi dei loro collegamenti. Fortunatamente, in questo caso, il ritardo della porta NOT sembra non pregiudicare il funzionamento del sistema, infatti il master e lo slave funzionano alternativamente, cosa che potrebbe non accadere se il ritardo della porta NOT fosse troppo grande e quindi non si riuscisse a determinare l'uscita. Questo però è un caso limite poiché di solito il ritardo della porta NOT è un  $\tau$  piccolissimo.



Figura 3.14: Simulazione del Flip-Flop RS Master-Slave Post-Route



# Capitolo 4

# Display a 7 segmenti

## 4.1 Traccia

Illustrare la realizzazione di un'architettura che consenta di mostrare su un array di 4 display a 7 segmenti un valore intero. Tale puo essere una parola da 16 bit, composta cioè di 4 cifre esadecimali, ciascuna espressa su di un nibble (4 bit). Sviluppare la traccia discutendo l'approccio di design adottato.

## 4.2 Soluzione

#### 4.2.1 Schematici

### 4.2.1.1 Display a 7 segmenti

L'approccio di design adottato è rappresentato dallo schematico dell'architettura in figura 5.1.





Figura 4.1: Architettura del display a sette segmenti

Gli input sono rappresentati da: un segnale di clock, uno di reset in logica 0 attiva, le abilitazioni per le quattro cifre del display, i valori che le stesse cifre devono assumere e l'eventuale posizione dei punti da accendere. Gli output sono costituiti dai segnali degli anodi comuni ai sette segmenti, uno per ciascuna cifra, e dai segnali dei catodi, sette dei quali in riferimento ai segmenti della cifra in questione, l'ultimo relativo al punto ad essa associato.

Il segnale di clock è filtrato da un clock filter, che restituisce un segnale di hit a frequenza minore. Il clock permette, inoltre, il conteggio al contatore modulo 4, abilitato dal segnale di hit del clock filter. Il reset, se negato, consente il ripristino del clock filter e del contatore. L'uscita del contatore consente di selezionare una cifra del display ad ogni conteggio. Infatti, avendo le quattro cifre i catodi dei segmenti in comune, per mostrare un valore differente su ciascuna di esse è necessario un refresh del valore con una frequenza sufficientemente elevata.

I segnali di abilitazione permettono di decidere quali cifre del display utilizzare. Essi, in ingresso ad un multiplexer 4x1, sono selezionati dal contatore per considerare in ogni istante l'abilitazione legata alla cifra corrente. L'abilitazione così individuata identifica l'anodo relativo attraverso un demultiplexer 1x4, sempre tramite la selezione del contatore. Ad ogni conteggio, la cifra selezionata avrà anodo basso o alto, a seconda dei valori di abilitazione passati in ingresso.

I 16 bit di ingresso dei valori rappresentano i quattro nibble relativi alle quattro cifre del display. Una struttura di multiplexing seleziona, in riferimento ai valori di conteggio, il nibble relativo alla cifra corrente. I 4 bit del nibble entrano in un transcodificatore per la corretta accensione dei sette segmenti della cifra.

L'ottavo catodo della cifra è costituito dal punto ad essa associato. I quattro segnali di ingresso dei punti, infatti, decretano se il punto, associato alla cifra selezionata, debba essere acceso, o meno. Un multiplexer 4x1 seleziona, grazie al conteggio, il valore corretto da assegnare al punto della cifra corrente.

L'implementazione dell'architettura è stata realizzata mediante la rappresentazione RT Level di figura 4.2.



Figura 4.2: Display RTL Schematic

#### 4.2.1.2 Struttura di multiplexing 16x4

Esplodiamo l'architettura che consente la selezione del nibble relativo alla cifra corrente del conteggio. Essa è realizzata mediante 4 multiplexer 4x1, ognuno dei quali riceve in ingresso un bit di pari peso dei nibble associati alle diverse cifre. L'ingresso di selezione è costituito dall'uscita del contatore.



Figura 4.3: Architettura di multiplexing 16x4

#### 4.2.2 Codice

Display sette segmenti ISE

#### 4.2.2.1 Clock Filter

Il clock filter riceve in ingresso un segnale di reset in logica 0 attiva per ritornare ad uno stato neutro in modo asincrono all'elaborazione del conteggio. Esso funge da divisore di frequenza, restituendo il segnale hit con una frequenza sottomultipla di quella del clock in ingresso. Il rapporto tra le due frequenze rappresenta il numero di conteggi da effettuare dopo il quale il filtro deve alzare hit (nemero di colpi di clock in un periodo di hit). Non si è potuto sfruttare un contatore modulo  $2^N$  perché non è detto che il conteggio sia potenza di 2.

```
library IEEE;
  use IEEE.STD_LOGIC_1164.ALL;
3
  entity clock_filter is
4
                 freq_clock : NATURAL := 50000000;
    Generic (
5
           freq_hit : NATURAL := 250
6
          );
       Port ( reset_n : in STD_LOGIC;
8
              clk : in
                         STD_LOGIC;
              hit : out STD_LOGIC
10
       );
11
```

```
end clock_filter;
12
13
   architecture Behavioral of clock_filter is
14
   constant freq_ratio : NATURAL := freq_clock/freq_hit;
15
  begin
16
   -- Ho bisogno di un contatore N
17
     hit_counter_n : process(clk, reset_n)
18
     variable count : NATURAL := 0;
19
     begin
20
       if reset n = '0' then
21
         count := 0;
22
         hit <= '0';
23
       elsif rising_edge(clk) then
24
         if count = (freq_ratio-1) then
25
           count := 0;
26
           hit <= '1';
27
         else
28
           count := count + 1;
29
           hit <= '0';
30
         end if;
31
       end if;
32
     end process;
33
   end Behavioral;
34
```

**Codice Componente 4.1:** Definizione del componente Clock Filter

#### 4.2.2.2 Anode Manager

Il gestore degli anodi utilizza una rete mux-demux per abilitare ad ogni conteggio l'anodo corretto. L'uscita del contatore rappresenta l'ingresso di selezione sia per il multiplexer, che per il demultiplexer. Gli ingressi di abilitazione entrano in un mux 4x1. L'uscita del multiplexer è posta in ingresso al demultiplexer. Lo stesso segnale di selezione garantisce che l'abilitazione sarà portata fino all'anodo a cui essa fa riferimento.

```
library IEEE;
  use IEEE.STD_LOGIC_1164.ALL;
2
3
  entity anode_manager is
       Port ( counter : in STD_LOGIC_VECTOR (1 downto 0);
           en : in STD_LOGIC_VECTOR (3 downto 0);
6
                        STD_LOGIC_VECTOR (3 downto 0)
7
         anodes : out
         );
8
  end anode_manager;
9
10
  architecture structural of anode_manager is
11
12
  component muxn_1 is
13
    generic(address_width : natural := 3);
14
    port (
15
```

```
SEL : in STD_LOGIC_VECTOR(address_width-1 downto 0);
16
       A : in STD_LOGIC_VECTOR(2**address_width-1 downto 0);
17
       X : out STD_LOGIC
18
     );
19
   end component;
20
21
   component demux1_n is
22
     generic(address width : natural := 2);
23
24
       a : in std_logic;
25
       sel : in std_logic_vector(address_width-1 downto 0);
26
       x : out std logic vector(2**address width-1 downto 0)
27
     );
28
   end component;
29
   for all : demux1_n use entity WORK.demux1_n(dataflow);
30
31
   signal enable_anode : STD_LOGIC := '0';
32
33
   begin
34
35
     inst mux4 1 : muxn 1
36
       generic map ( address_width => 2 )
37
       port map ( SEL => counter,
38
                A => en,
39
                X => enable anode
40
              );
41
42
     inst_demux4_1 : demux1_n
43
       generic map ( address_width => 2
44
       port map ( sel => counter,
45
                a => enable_anode,
46
                x => anodes
47
              );
48
49
  end structural;
```

Codice Componente 4.2: Definizione del componente Anode Manager

#### 4.2.2.3 Cathode Manager

Il gestore dei catodi riceve in ingresso il conteggio, i valori che i catodi dei sette segmenti devono assumere e quelli del catodo dei punti. L'uscita è costituita dagli 8 segnali dei catodi. Il componente sfrutta la struttura di multiplexing descritta in 4.2.1.2. Per fare ciò riordina i valori di ingresso nel modo richiesto dalla batteria di mux 4x1. Il nibble così ottenuto entra nel transcodificatore, realizzato col componente cathode encoder, dal quale si ottengono i segnali dei catodi dei sette segmenti. Il segnale dell'ultimo catodo è ricavato dal multiplexing dei valori dei punti in ingresso: un mux 4x1 determina quale valore porre in uscita sul catodo.

```
library IEEE;
```

```
use IEEE.STD_LOGIC_1164.ALL;
2
  entity cathode_manager is
4
       Port ( counter : in STD_LOGIC_VECTOR (1 downto 0);
5
           values : in STD_LOGIC_VECTOR (15 downto 0);
           dots : in STD_LOGIC_VECTOR (3 downto 0);
         cathodes : out STD_LOGIC_VECTOR (7 downto 0)
         );
  end cathode_manager;
10
11
  architecture structural of cathode_manager is
12
13
   component muxn_1 is
14
    generic(address_width : NATURAL := 3);
15
    port (
16
       SEL : in STD_LOGIC_VECTOR(address_width-1 downto 0);
17
       A : in STD_LOGIC_VECTOR(2**address_width-1 downto 0);
18
       X : out STD_LOGIC
19
    );
20
  end component;
21
22
  component cathode_encoder is
23
       Port ( nibble : in STD LOGIC VECTOR (3 downto 0);
24
              cathodes : out STD_LOGIC_VECTOR (6 downto 0)
25
       );
26
  end component;
27
  for all : cathode_encoder use entity WORK.cathode_encoder(behavioral);
28
29
  signal nibble : STD_LOGIC_VECTOR (3 downto 0) := (others => '0');
30
  alias digit0 : STD_LOGIC_VECTOR(3 downto 0) is values(3 downto 0);
31
  alias digit1 : STD_LOGIC_VECTOR(3 downto 0) is values(7 downto 4);
32
  alias digit2 : STD_LOGIC_VECTOR(3 downto 0) is values(11 downto 8);
33
  alias digit3 : STD_LOGIC_VECTOR(3 downto 0) is values(15 downto 12);
34
  signal in_mux : STD_LOGIC_VECTOR (15 downto 0) := (others => '0'); --per
35
      ordinare i valori da porre in ingresso ai mux 4x1
36
  begin
37
38
    mux16_4 : for i in 0 to 3 generate
39
       in_mux((i*4+3) downto i*4) \le (digit3(i), digit2(i), digit1(i), digit0(i)
40
          ));
       -- i=0 --> in mux(3 downto 0)
41
       -- i=1 --> in_mux(7 downto 4)
42
       -- i=2 --> in_mux(11 downto 8)
43
       -- i=3 --> in_mux(15 downto 12)
44
       inst_mux4_1 : muxn_1
45
         generic map ( address_width => 2 )
46
         port map ( SEL => counter,
47
               A \Rightarrow in_{mux}((i*4+3) downto i*4),
48
```

```
X => nibble(i)
49
               );
50
     end generate;
51
52
     inst_encoder : cathode_encoder
       port map ( nibble => nibble,
54
               cathodes => cathodes (6 downto 0)
55
             );
56
57
     inst_dots_manager : muxn_1
58
       generic map ( address_width => 2 )
59
         port map ( SEL => counter,
60
                 A => dots,
61
                 X => cathodes(7)
62
63
64
   end structural;
65
```

Codice Componente 4.3: Definizione del componente Cathode Manager

#### 4.2.2.4 Cathode encoder

Questo componente effettua la funzione di transcodifica di un nibble nelle funzioni booleane dei sette segmenti. Esso, dunque, riceve in input un nibble e restituisce il valore assunto dai catodi dei sette segmenti.

```
library IEEE;
use IEEE.STD_LOGIC_1164.ALL;

entity cathode_encoder is
    Port ( nibble : in STD_LOGIC_VECTOR (3 downto 0);
        cathodes : out STD_LOGIC_VECTOR (6 downto 0)
    );
end cathode_encoder;
```

Codice Componente 4.4: Interfaccia del componente Cathode Encoder

A scopo didattico, la sua implementazione è stata effettuata seguendo differenti approcci.

**Behavioral** Questo approccio comportamentale prevede, appunto, la specifica del comportamento dell'uscita in concomitanza a ciascuna combinazione degli ingressi mediante costrutto *case-when*. Sono state definite delle costanti per ogni caso al fine di migliorare la leggibilità.

```
architecture Behavioral of cathode_encoder is

constant digit0 : std_logic_vector(6 downto 0) := "10000000";

constant digit1 : std_logic_vector(6 downto 0) := "1111001";

constant digit2 : std_logic_vector(6 downto 0) := "0100100";

constant digit3 : std_logic_vector(6 downto 0) := "0110000";

constant digit4 : std_logic_vector(6 downto 0) := "0011001";
```

```
constant digit5 : std_logic_vector(6 downto 0) := "0010010";
8
   constant digit6 : std_logic_vector(6 downto 0) := "0000010";
   constant digit7 : std_logic_vector(6 downto 0) := "1011000";
10
   constant digit8 : std_logic_vector(6 downto 0) := "0000000";
11
   constant digit9 : std_logic_vector(6 downto 0) := "0010000";
12
   constant digitA : std_logic_vector(6 downto 0) := "0001000";
13
   constant digitB : std_logic_vector(6 downto 0) := "0000011";
14
   constant digitC : std_logic_vector(6 downto 0) := "1000110";
15
   constant digitD : std_logic_vector(6 downto 0) := "0100001";
16
   constant digitE : std_logic_vector(6 downto 0) := "0000110";
17
   constant digitF : std_logic_vector(6 downto 0) := "0001110";
18
19
   begin
20
     main_cathode : process(nibble)
21
     begin
22
       case nibble is
23
         when x"0" =>
24
           cathodes <= digit0;</pre>
25
         when x"1" =>
26
           cathodes <= digit1;
27
         when x"2" =>
28
           cathodes <= digit2;
29
         when x"3" =>
30
           cathodes <= digit3;
31
         when x"4" =>
32
           cathodes <= digit4;
33
         when x"5" =>
34
           cathodes <= digit5;
35
         when x''6'' =>
36
           cathodes <= digit6;
37
         when x"7" =>
38
           cathodes <= digit7;
39
         when x"8" =>
40
           cathodes <= digit8;
41
         when x"9" =>
42
           cathodes <= digit9;
43
         when x"A" =>
44
           cathodes <= digitA;
45
         when x"B" =>
46
           cathodes <= digitB;
47
         when x"C" =>
48
           cathodes <= digitC;
49
         when x"D" =>
50
           cathodes <= digitD;
51
         when x"E" =>
52
           cathodes <= digitE;</pre>
53
         when x"F" =>
54
           cathodes <= digitF;</pre>
55
         when others =>
56
```

```
cathodes <= (others => '1');
end case;
end process;
end Behavioral;
```

Codice Componente 4.5: Architettura Behavioral del componente Cathode Encoder

**Structural** Questo approccio realizza il transcodificatore con 7 mux 8x1, mostrando l'utilizzo del multiplexer come rete universale. I 3 bit più significativi del nibble vanno a costituire l'ingresso di selezione dei multiplexer, mentre il bit meno significativo permette la codifica degli ingressi. In figura 4.4 viene rappresentato il caso per la funzione booleana del segmento A. Si assumono gli ingressi denominati come x, y, z, v, a partire dal bit più significativo.



Figura 4.4: Multiplexer 8x1 che realizza la funzione booleana del segmento A

Dopo la costruzione dei vettori degli ingressi per ogni multiplexer, si è definito un vettore di vettori per consentire una generazione della struttura mediante il costrutto for-generate.

```
architecture structural of cathode_encoder is
    COMPONENT muxn_1
2
    generic(address_width : natural := 3);
       SEL : IN std_logic_vector(address_width-1 downto 0);
5
      A : IN std_logic_vector(2**address_width-1 downto 0);
6
      X : OUT std logic
7
      );
8
    END COMPONENT;
9
  alias v : std_logic is nibble(0);
10
  constant width : natural := 3;
11
  signal in_A : std_logic_vector(7 downto 0) := (others => '1');
12
  signal in B : std logic vector(7 downto 0) := (others =>
13
  signal in_C : std_logic_vector(7 downto 0) := (others => '1');
14
  signal in_D : std_logic_vector(7 downto 0) := (others => '1');
15
  signal in_E : std_logic_vector(7 downto 0) := (others => '1');
16
  signal in_F : std_logic_vector(7 downto 0) := (others => '1');
17
  signal in_G : std_logic_vector(7 downto 0) := (others => '1');
  type array_bidim is array (6 downto 0) of std_logic_vector(7 downto 0);
```

```
signal ingressi : array_bidim := (others => (others => '1'));
20
                begin
21
                            in_A(7 \text{ downto } 0) \le (0 \Rightarrow v, 1 \Rightarrow '0', 2 \Rightarrow \text{not } v, 3 \Rightarrow '0', 4 \Rightarrow '0', 5
22
                                                => v, 6 => v, 7 => '0');
                            in_B(7 \text{ downto } 0) \le (0 \Rightarrow '0', 1 \Rightarrow '0', 2 \Rightarrow v, 3 \Rightarrow \text{not } v, 4 \Rightarrow '0', 5
23
                                                => v, 6 => not v, 7 => '1');
                            in_C(7 \text{ downto } 0) \le (0 \Rightarrow '0', 1 \Rightarrow \text{ not } v, 2 \Rightarrow '0', 3 \Rightarrow '0', 4 \Rightarrow '0', 5
24
                                                       => '0', 6 => not v, 7 => '1');
                            in_D(7 \text{ downto } 0) \le (0 \Rightarrow v, 1 \Rightarrow '0', 2 \Rightarrow \text{ not } v, 3 \Rightarrow v, 4 \Rightarrow '0', 5 \Rightarrow
25
                                                not v, 6 => '0', 7 => v);
                            in_E(7 \text{ downto } 0) \le (0 => v, 1 => v, 2 => '1', 3 => v, 4 => v, 5 => '0', 6
26
                                                      => '0', 7 => '0');
                            in_F(7 \text{ downto } 0) \le (0 \Rightarrow v, 1 \Rightarrow '1', 2 \Rightarrow '0', 3 \Rightarrow '0', 4 \Rightarrow '0', 5 \Rightarrow (0 \Rightarrow v, 1 \Rightarrow '1', 2 \Rightarrow '0', 3 \Rightarrow '0', 4 \Rightarrow '0', 5 \Rightarrow (0 \Rightarrow v, 1 \Rightarrow '1', 2 \Rightarrow '0', 3 \Rightarrow '0', 4 \Rightarrow '0', 5 \Rightarrow (0 \Rightarrow v, 1 \Rightarrow v, 1 \Rightarrow '1', 2 \Rightarrow '0', 3 \Rightarrow '0', 4 \Rightarrow '0', 5 \Rightarrow (0 \Rightarrow v, 1 \Rightarrow v, 
27
                                                '0', 6 => v, 7 => '0');
                            in_G(7 \text{ downto } 0) \le (0 \Rightarrow '1', 1 \Rightarrow '0', 2 \Rightarrow '0', 3 \Rightarrow v, 4 \Rightarrow '0', 5 \Rightarrow
28
                                                 '0', 6 => not v, 7 => '0');
                            ingressi <= (in_G, in_F, in_E, in_D, in_C, in_B, in_A);</pre>
29
30
                            setteseg : for i in 0 to 6 generate
31
                                         Inst_muxn_1: muxn_1 GENERIC MAP(width) PORT MAP(
^{32}
                                                     SEL => nibble(3 downto 1),
33
                                                    A => ingressi(i),
34
                                                    X => cathodes(i)
35
                                         );
36
                            end generate;
37
                 end structural;
38
```

Codice Componente 4.6: Architettura Structural del componente Cathode Encoder

**Dataflow** Denominati gli ingressi come nel paragrafo precendete, si è provveduto a definire un file blif per la funzione multi-uscita dei sette segmenti. In tal modo è stata possibile una minimizzazione con SIS attraverso l'uso del *rugged-script*.

```
pi= 4
                                              latch= 0
                                                           lits(sop) = 132
                                                                                 lits(ff)=
                                                                                                96
               -x script.rugged
     source
 weep; eliminate
 segmenti
segmenti
             pi= 4
pi= 4
                       po= 7
po= 7
                                              latch= 0
latch= 0
                                                           lits(sop)= 132
lits(sop)= 132
                                                                                 lits(ff)=
lits(ff)=
                                node=
                       po=
                                node=
           -m nocomp
                       po = 7
                                          7
                                              latch= 0
                                                           lits(sop)=
                                                                           59
                                                                                 lits(ff)=
                                                                                                51
              pi= 4
                                node=
  iminate
             pi= 4
                                                           lits(sop)=
                       po= 7
                                              latch= 0
                                                                            59
                                                                                 lits(ff)=
                                                                                                51
                                node=
 segmenti
weep; eliminate
segmenti
segmenti
             pi= 4
pi= 4
                                                            lits(sop)=
lits(sop)=
                                                                            59
59
                                                                                 lits(ff)=
lits(ff)=
                       po=
                                node=
                                              latch= 0
                                          ż
                            ż
                                              latch= 0
                                node=
                       p_0 =
implify
                       po = 7
segmenti
                                node=
                                          7
                                              latch= 0
                                                            lits(sop)=
                                                                            59
                                                                                 lits(ff)=
                                                                                                51
                       po = 7
                                node=
                                              latch= 0
                                                            lits(sop)=
                                                                            59
                                                                                 lits(ff)=
                                                                                                51
segmenti
                                                                                 lits(ff)=
?segmenti
             pi= 4
                       po = 7
                                node=
                                          9
                                              latch= 0
                                                            lits(sop)=
                                                                            55
                                                                                                51
resub —a;
7segmenti
           sweep
                                                                                 lits(ff)=
lits(ff)=
                                                           lits(sop)=
lits(sop)=
                       po=
                                node=
                                              latch= 0
latch= 0
                       po=
segmenti
                                node=
liminate
              pi=
              pi= 4
pi= 4
                                              latch= 0
latch= 0
                                                            lits(sop)=
lits(sop)=
                       po=
                                                                                 lits(ff)=
lits(ff)=
7segmenti
                                node=
                       po= 7
 segmenti
                                 node=
                     nocomp
 ull_simplify
                                                            lits(sop)=
lits(sop)=
                                                                            55
55
 segmenti
                                 node=
                                              latch=
                                                       Ø
```

Figura 4.5: Funzione multi-uscita dei sette segmenti minimizzata col rugged-script

Ogni uscita è calcolata in base alla forma minimizzata della funzione corrispondente.

```
architecture dataflow of cathode encoder is
2
   alias x : std_logic is nibble(3);
3
   alias y : std_logic is nibble(2);
   alias z : std_logic is nibble(1);
5
   alias v : std_logic is nibble(0);
6
7
   -- generati dalla minimizzazione
   signal t7 : std_logic := '1';
9
   signal t8 : std_logic := '1';
10
   -- cathodes(i) non puo' essere usato per definire un'altra uscita, essendo
11
      un segnale di output
   signal A : std logic := '1';
12
   signal B : std_logic := '1';
13
   signal C : std_logic := '1';
14
   signal D : std_logic := '1';
15
   signal E : std_logic := '1';
16
   signal F : std_logic := '1';
17
   signal G : std_logic := '1';
18
19
  begin
20
     t7 \ll (not z) or (not y);
21
     t8 \le (not x) and (not y);
22
23
     cathodes (0) \le A;
24
     cathodes(1) <= B;
25
```

```
cathodes(2) <= C;
26
      cathodes (3) \le D;
27
      cathodes (4) <= E;
28
      cathodes (5) \ll F;
29
      cathodes(6) <= G;
30
31
      A \le (v \text{ and } (not E) \text{ and } t7) \text{ or } ((not z) \text{ and } E \text{ and } G) \text{ or } ((not v) \text{ and } E);
32
      B \le (v \text{ and (not } E) \text{ and (not } F)) \text{ or (y and (not D) and (not F))};
33
      C \le ((not E) \text{ and } (not G) \text{ and } t8) \text{ or } (x \text{ and } y \text{ and } (not A));
34
      D \le ((not y) and z and (not v) and (not C)) or (v and (not t7)) or (A and
35
      E \le ((not y) and (not z) and v) or ((not x) and y and (not z)) or ((not x)
36
           ) and v);
      F \le ((not z) \text{ and } A \text{ and } (not E)) \text{ or } (E \text{ and } t8) \text{ or } ((not y) \text{ and } C);
37
      G \le (y \text{ and (not } z) \text{ and (not } v) \text{ and (not } E)) \text{ or ((not } z) \text{ and t8) or (E and } v)
38
             (not t7));
```

Codice Componente 4.7: Architettura Dataflow del componente Cathode Encoder

#### 4.2.2.5 Display

Il display non fa altro che realizzare la struttura descritta in 4.2.1.1. Sono infatti istanziati e collegati nel modo descritto i componenti cui abbiamo fatto riferimento.

```
library IEEE;
  use IEEE.STD_LOGIC_1164.ALL;
3
  entity display is
4
                 freq_clock : NATURAL := 50000000;
    Generic (
5
           freq_hit : NATURAL := 250
           );
               rst_n : in STD_LOGIC;
     Port (
         clock : in STD_LOGIC;
         en : in STD_LOGIC_VECTOR (3 downto 0);
10
         values : in STD_LOGIC_VECTOR (15 downto 0);
11
         dots : in STD_LOGIC_VECTOR (3 downto 0);
12
         anodes : out STD_LOGIC_VECTOR (3 downto 0);
13
         cathodes : out STD_LOGIC_VECTOR (7 downto 0)
14
         );
15
  end display;
16
17
  architecture structural of display is
18
19
  component counter_mod2n is
20
    generic ( width : NATURAL := 2);
^{21}
    port ( en : in STD_LOGIC;
22
         reset_n : in STD_LOGIC;
23
                  STD_LOGIC;
         clk : in
24
                 STD_LOGIC_VECTOR (width-1 downto 0)
25
```

```
);
26
   end component;
27
28
   component clock_filter is
29
     Generic (
                  freq_clock : NATURAL := 50000000;
30
              freq_hit : NATURAL := 250
31
          );
32
33
       Port ( reset_n : in STD_LOGIC;
               clk : in STD_LOGIC;
34
              hit : out STD LOGIC
35
       );
36
   end component;
37
38
   component cathode_manager is
39
       Port ( counter : in STD_LOGIC_VECTOR (1 downto 0);
40
           values : in STD_LOGIC_VECTOR (15 downto 0);
41
           dots : in STD_LOGIC_VECTOR (3 downto 0);
42
         cathodes : out STD_LOGIC_VECTOR (7 downto 0)
43
         );
44
   end component;
45
46
   component anode_manager is
47
       Port ( counter: in STD LOGIC VECTOR (1 downto 0);
48
           en : in STD_LOGIC_VECTOR (3 downto 0);
49
         anodes : out STD LOGIC VECTOR (3 downto 0)
50
         );
51
   end component;
52
53
54
   signal hit : STD_LOGIC := '0';
55
   signal sel: STD_LOGIC_VECTOR(1 downto 0) := (others => '0');
56
57
  begin
58
     inst_clk_fliter : clock_filter
59
       generic map ( freq_clock => freq_clock,
60
                freq_hit => freq_hit )
61
       port map ( reset_n => rst_n,
62
             clk => clock,
63
             hit => hit
64
             );
65
     inst_counter : counter_mod2n
66
       generic map ( width => 2 )
67
       port map ( en => hit,
68
             reset_n => rst_n,
69
             clk => clock,
70
             q \Rightarrow sel
71
72
             );
73
     inst_cathode_manager : cathode_manager
74
```

```
port map ( counter => sel,
75
              values => values,
76
              dots => dots,
77
              cathodes => cathodes
78
              );
79
80
     inst_anode_manager : anode_manager
81
       port map ( counter => sel,
82
              en => en,
83
              anodes => anodes
84
              );
85
86
   end structural;
```

**Codice Componente 4.8:** Definizione del componente Display

#### 4.3 Simulazione

Per la simulazione sono state valutate differenti configurazioni degli ingressi mediante il costrutto for-loop.

```
-- Stimulus process
1
      stim_proc: process
2
      begin
       rst_n <= '0';
         -- hold reset state for 100 ns.
         wait for 100 ns;
         wait for clock_period*10;
9
         -- insert stimulus here
10
       for t in std_logic range '0' to '1' loop
11
         rst_n <= not t;
12
         for i in 0 to 2 loop
13
           en <= std_logic_vector(to_unsigned(i*4, 4));</pre>
14
           dots <= std_logic_vector(to_unsigned(i*4, 4));</pre>
15
           -- i = 0 --> en = dots = 0000
16
           -- i = 1 --> en = dots = 0100
17
           -- i = 2 --> en = dots = 1000
1.8
           for j in 1 to 2 loop
19
             values <= std_logic_vector(to_unsigned(j*8, 16));</pre>
20
              -- j = 1 --> values = 0000 0000 0000 1000
21
              -- j = 2 --> values = 0000 0000 0001 0000
22
              wait for freq_clock/freq_hit*clock_period*4; -- per osservare un
23
                 ciclo del contatore
           end loop;
24
         end loop;
^{25}
       end loop;
26
```

```
27
28  wait;
29  end process;
30
31  END;
```

Codice Componente 4.9: Simulazione del componente Display

Di seguito il segnale values sarà rappresentato in esadecimale. In figura 4.6 osserviamo come al variare di values segue la commutazione del segnale cathodes in modo coerente al conteggio. Quando infatti il valore di ingresso è pari a x"0008", al primo conteggio i catodi seguono l'ingresso diverso per la prima cifra. Analogamente per la seconda cifra quando il valore di ingresso è pari a x"0010".



Figura 4.6: Simulazione del display: i catodi seguono correttamente il valore di ingresso per i sette segmenti delle diverse cifre

In figura 4.7 notiamo che, al variare di *en* e *dots*, segue la commutazione di *anodes* e *cathodes*, coerentemente al valore di conteggio. Quando, infatti, i segnali di abilitazione e dei punti sono pari a x"0100", al conteggio associato alla terza cifra seguono nella commutazione anche il relativo anodo e il catodo che rappresenta il punto.



Figura 4.7: Simulazione del display: gli anodi seguono correttamente i valori di abilitazione; il catodo del punto segue correttamente i valori dei punti

Con  $rst_n$  pari a 0, ovvero il segnale di reset attivo, il conteggo si blocca alla prima cifra. Osserviamo in figura 4.8 che le uscite segnano identicamente i valori relativi alla prima cifra, indipendentemente dalla variazione degli altri ingressi. Esse infatti non sono sensibili alle variazioni di en e dots sulla terza cifra ("0100"), ma notiamo una commutazione al variare di values sulla prima cifra (x"0008").



Figura 4.8: Simulazione del display: il reset basso blocca il conteggio alla prima cifra

#### 4.4 Sintesi su board FPGA

La soluzione adottata per interfacciare il design con la board fa uso di una semplice unità di controllo. Essa consente di ricevere i valori di input tramite gli interruttori della board, e caricarli nei registri relativi mediante i pulsanti. Il segnale di clock è associato al clock della board, il reset ed i tre bit di loader sono associati ai quattro pulsanti, in\_byte agli otto interruttori, anodes ai quattro anodi e cathodes agli otto catodi. Sono utilizzate tre batterie di otto flip flop D edge triggered per salvare l'input nel giusto registro a seconda del pulsante premuto. Esse, infatti, hanno per abilitazione ciascuna un differente bit di caricamento (button), e quindi un differente pulsante. Il reset negato ed i vari registri sono poi collegati al display. Per i punti, il registro è collegato al display in forma negata. Ciò perché sono presi in input i punti da abilitare, abilitazione che corrisponde a valle ad un abbassamento del catodo relativo. Infine, si noti che gli anodi della board sono associati al valore negato di quelli in uscita dal display: essi sono pilotati con una logica 0 attiva, di questo se ne occupa il componente display on board che con un process controlla se è stato premuto il primo pulsante così da usare l' input in ingresso per abilitare solo determinate cifre o punti; con il secondo invece si carica il valore da voler visualizzare sul display.

```
entity display_top_level is
     Generic ( freq_clock : integer := 50000000;
2
            freq_hit : integer := 250
3
           );
       Port ( clock : in
                           STD_LOGIC;
              reset : in
                           STD_LOGIC;
                load lsb value : in
                                       STD LOGIC;
7
                load_msb_value : in
                                       STD LOGIC;
                load dots enable : in
                                         STD LOGIC;
9
           load_conf :in STD_LOGIC;
1.0
           load_value : in STD_LOGIC;
11
           number: in STD_LOGIC_VECTOR (15 downto 0);
12
                             STD_LOGIC_VECTOR (7 downto 0);
              in_byte : in
13
                             STD_LOGIC_VECTOR (3 downto 0);
              anodes : out
14
                                STD_LOGIC_VECTOR (7 downto 0));
15
  end display_top_level;
16
17
  architecture structural of display_top_level is
18
^{19}
   component display_on_board is
20
       Port ( clock : in STD_LOGIC;
21
              reset : in STD LOGIC;
22
                 load lsb value : in
                                       STD LOGIC;
23
                 load msb value : in
                                       STD LOGIC;
24
                load_dots_enable : in
                                         STD LOGIC;
25
           load_conf :in STD_LOGIC;
26
           load_value : in STD_LOGIC;
27
           number: in STD_LOGIC_VECTOR (15 downto 0);
28
              in_byte : in STD_LOGIC_VECTOR (7 downto 0);
29
              value : out
                            STD_LOGIC_VECTOR (15 downto 0);
30
              dots : out
                           STD_LOGIC_VECTOR (3 downto 0);
31
                         STD_LOGIC_VECTOR (3 downto 0));
              en : out
32
```

```
end component;
33
   component display is
34
     Generic ( freq_clock : integer := 50000000;
35
            freq_hit : integer := 250
36
           );
37
      Port ( rst_n : in STD_LOGIC;
38
          clock : in STD_LOGIC;
39
             en : in STD LOGIC VECTOR (3 downto 0);
40
             values : in STD_LOGIC_VECTOR (15 downto 0);
41
             dots : in STD_LOGIC_VECTOR (3 downto 0);
42
             anodes : out STD_LOGIC_VECTOR (3 downto 0);
43
             cathodes : out STD_LOGIC_VECTOR (7 downto 0));
44
   end component;
45
   signal value : STD_LOGIC_VECTOR (15 downto 0) := (others => '0');
46
   signal dots : STD_LOGIC_VECTOR (3 downto 0) := (others => '1');
47
   signal en : STD_LOGIC_VECTOR (3 downto 0) := (others => '1');
48
   signal rst_n : STD_LOGIC := '1';
49
  begin
50
     rst_n <= not(reset);</pre>
51
     inst_on_board : display_on_board
52
53
       port map ( clock => clock,
                reset => reset,
54
                  load lsb value => load lsb value,
55
                  load_msb_value => load_msb_value,
56
                  load dots enable => load dots enable,
57
                load_conf => load_conf,
58
                load value => load value,
59
                number => number,
                in_byte => in_byte,
61
                value => value,
62
                dots => dots,
63
                en => en
64
               );
65
     inst_display : display
66
     generic map( freq_clock => freq_clock,
67
                 freq_hit => freq_hit
68
69
       port map ( clock => clock,
70
                rst_n => rst_n,
71
                values => value,
72
                dots => dots,
73
                en => en,
74
                anodes => anodes,
75
                cathodes => cathodes
76
77
   end structural;
78
```

Codice Componente 4.10: Architettura della Control Unit

## Capitolo 5

## Clock Generator

## 5.1 Traccia

Illustriamo come un DCM, posso essere sostituito al clock\_filter del Display a 7 segmenti, per avere un segnale di abilizatione, per sostiturlo al clock\_filter utilizzato nell' esercizio precedente.

#### 5.2 Soluzione

#### 5.2.1 Schematici



Figura 5.1: Architettura del display a sette segmenti

Utilizzando il wizard di xilinx per la creazione degli ip core, possiamo chiedere di creare un DCM che con un a frequenza in input di 50 MHz ci restituisca in uscita un segnale periodico con frequenza di 5 MHz, la frequenza desiderata è molto alta rispetto a quella che basterebbe per visualizzare le cifre sul display, infatti si notano alcuni sfarfalii, si potrebbe risolvere utilizzando una struttura a doppio DCM, per far si che il numero di possibili frequenze a disposizioni aumentino, ci accontentiamo della soluzione ad un singolo DCM essendo le cifre visibili sul display.

#### **5.2.2** Codice

DCM ISE

### 5.3 Simulazione

Fare riferimento alla simulazione del display 4.3.

## 5.4 Sintesi su board FPGA

Fare riferimento a 4.4.



## Capitolo 6

## Scan Chain

#### 6.1 Traccia

Progettare una rete composta da una serie di N Flip Flop D abilitati ad operare nei seguenti due modi:

- 1. Modalità normale: l'array si comporta come un registro di N posizioni;
- 2. Modalità controllo: i flip flop possono essere scritti e letti individualmente configurandoli in cascata come uno shift register.

Utilizzare una rete di controllo in grado di alimentare il primo stadio con un valore e generare tanti colpi di clock quanto è la distanza del primo stadio dalla cella da raggiungere.

## 6.2 Soluzione

#### 6.2.1 Schematici

La seguente Boundary Scan Chain è realizzata a partire da quattro flip flop edge triggered che in ingresso prendono l'uscita di un multiplexer che, pilotato da un segnale di scan\_en, decide di selezionare o un ingresso utente din oppure l'uscita del flip flop precedente. Quindi quando scan\_en è basso il sistema funziona in modalità registro, conservando il dato din, altrimenti funziona da shift-register, shiftando i valori in ingresso al segnale scan\_in, fino a quello di scan\_out dopo un numero di colpi di clock pari al numero di registri.



Figura 6.1: Boundary Scan Chain

#### **6.2.2** Codice

Progetto ISE: Boundary Scan Chain ISE

### 6.2.2.1 Boundary\_Scan\_Chain

Questo componente è stato realizzato con un approccio Structural, componendo opportunamente dei flip-flop d edge triggered e dei mux 2-1. Quando  $scan\_en$  è basso, il segnale din viene salvato nel registro composto dai vari flip flop, nel caso in cui  $scan\_en$  sia attivo i vari flip flop vengono connessi modo tale che ad ogni colpo di clock, il valore di  $scan\_in$ venga salvato nel primo flip flop, il valore salvato nel primo venga propagato nel secondo e così via.

```
library IEEE;
  use IEEE.STD_LOGIC_1164.ALL;
  USE ieee.std_logic_arith.ALL;
3
  entity boundary_scan_chain is
    generic(n : natural := 4);
      Port ( scan_in : in STD_LOGIC;
7
              clk : in
                        STD LOGIC;
8
           reset n : in STD LOGIC;
                        STD_LOGIC_VECTOR (n-1 downto 0);
              din : in
10
              scan_en : in STD_LOGIC;
11
                               STD_LOGIC;
              scan_out : out
12
```

```
dout : out STD_LOGIC_VECTOR (n-1 downto 0)
13
      );
14
   end boundary_scan_chain;
15
16
   architecture Structural of boundary_scan_chain is
17
18
     component latch_d_en is
19
20
     generic(width:natural:=1);
       Port ( clk : in STD_LOGIC;
21
               reset : in STD LOGIC;
22
               en : in STD_LOGIC;
23
               d : in STD_LOGIC_VECTOR (width-1 downto 0);
24
                         STD_LOGIC_VECTOR (width-1 downto 0));
25
     end component;
26
27
     component mux2_1 is
28
       Port ( SEL : in STD_LOGIC;
29
                 : in STD_LOGIC;
30
             В
                 : in STD_LOGIC;
31
             Χ
                 : out STD_LOGIC
^{32}
33
       );
     end component;
34
35
   signal q : std_logic_vector(n-1 downto 0) := (others => '0');
36
   signal x,dinapp : std_logic_vector(n-1 downto 0) := (others => '0');
37
   signal s_out: std_logic:='0';
38
39
   begin
40
     chain_gen: for i in 0 to n-1 generate
41
       sc_in: if i=n-1 generate
42
         inst_mux2_1: mux2_1
43
         Port map( SEL => scan_en,
44
                 A => q(i-1),
45
                 B \Rightarrow din(i),
46
                 X => x(i)
47
         );
48
49
       inst_edge_triggered: latch_d_en generic map(width =>1)
50
         Port map ( clk => clk,
51
                 reset => reset n,
52
                 en => '1',
53
                 d(0) => x(i),
54
                 q(0) \Rightarrow q(i)
55
         );
56
       end generate sc_in;
57
       sc_ch: if i>0 and i<n-1 generate
58
         inst_mux2_1: mux2_1
59
           Port map( SEL => scan_en,
60
                  A => q(i-1),
61
```

```
B \Rightarrow din(i),
62
                    X => x(i)
63
            );
64
65
          inst_edge_triggered: latch_d_en generic map(width =>1)
            Port map ( clk => clk,
67
                   reset => reset_n,
68
                   en => '1',
69
                   d(0) => x(i),
70
                   q(0) => q(i)
71
          );
72
          end generate sc_ch;
73
        sc_out: if i=0 generate
74
        inst_mux2_1: mux2_1
75
          Port map ( SEL => scan_en,
76
                   A => scan_in,
77
                  B \Rightarrow din(i),
78
                  X => x(i)
79
          );
80
        inst_edge_triggered: latch_d_en generic map(width =>1)
81
          Port map( clk => clk,
                   reset => reset_n,
83
                   en => '1',
84
                   d(0) => x(i),
85
                   q(0) \Rightarrow q(i)
86
          );
87
       end generate sc_out;
88
     end generate;
     dout <=q;
90
     scan_out <= q(n-1);
91
   end Structural;
92
```

Codice Componente 6.1: Definizione della Boundary Scan Chain

## 6.3 Simulazione

In Figura 6.2 è osservabile il funzionamento del sistema appena descritto, utilizzando il testbench presente al seguente link: Boundary Scan Chain Testbench.

Come si nota è stata abilitata la modalità shift register ponendo ad 1 sia en, che scan\_en, in modo da shiftare il valore 1 posto in ingresso a scan\_in, che è visibile all'uscita scan\_out esattamente dopo quattro colpi di clock, come c'era d'aspettarsi dato che il numero di flip flop utilizzati è proprio quattro. Dopodiché si è scelto di abilitare la modalità registro e quindi a 55 ns sono stati abbassati sia en che scan\_en e difatti all'uscita dout dei flip flop si osserva il valore 1010 posto in ingresso precedentemente a din.



Figura 6.2: Simulazione della Boundary Scan Chain Behavioral



# Capitolo 7

## Finite State Machine

## 7.1 Traccia

Si voglia realizzare un macchina a stati finiti che permetta di riconoscere una stringa di bit, di dimensione generica.

## 7.2 Soluzione

### 7.2.1 Schematici



Figura 7.1: Riconoscitore di stringa

La macchina è composta semplicente da quattro stati:

- idle, in cui la macchina permane fintantoché non viene avviata la procedura di riconoscimento;
- carica\_stringa, in cui viene salvato in una scan chain il valore della stringa da riconoscere;
- shifting, in cui viene fatto shiftare il bit della stringa e far si ponga in uscita alla scan chain;
- riconosci\_bit, si determina se il bit in uscita della scan\_chain è uguale al bit della stringa da riconoscere ( quest' ultimo identificato dal valore di un contatore che opportunamente identifica il valore del bit da confrontare): se i due bit sono uguali, si procedere allo shifting ed al riconoscimento fino a quando non vengono confrontati tutti i bit ed un segnale indica che la stringa riconosciuta è proprio quella voluta; altrimenti viene abilitato un segnale che indica il fallimento della comparazione indicando la dissimilirità della stringa posta in ingresso da quella che si vuole riconoscere.

#### **7.2.2** Codice

#### 7.2.2.1 Riconoscitore stringa

Riconoscitore Stringa ISE

```
entity riconoscitore_stringa is
1
     generic(width: NATURAL:=8);
2
       Port ( clk : in STD_LOGIC;
           start: in STD_LOGIC;
           reset : in STD_LOGIC;
5
           data : in STD_LOGIC_VECTOR(width-1 downto 0);
6
           data_in : in STD_LOGIC;
           i: in STD_LOGIC_VECTOR(natural(ceil(log2(real(width)))) downto 0);
           en_res : out STD_LOGIC;
              shift : out STD_LOGIC;
10
              en_i : out STD_LOGIC;
11
           en c : out STD LOGIC;
12
           bad: out STD LOGIC;
13
           correct: out STD LOGIC);
14
  end riconoscitore_stringa;
15
16
  architecture Behavioral of riconoscitore_stringa is
17
  type state is (idle, riconosci_bit, shifting, carica_stringa);
18
19
  signal current_state : state;
  signal n:STD_LOGIC_VECTOR(natural(ceil(log2(real(width)))) downto 0):=(
20
      others=>'0');
  begin
21
  change_state: process (clk, reset)
22
    begin
23
       if (reset = '0') then
24
         current_state <= idle;
       elsif rising_edge(clk) then
26
       case current state is
27
```

```
when idle=> if start='1' then
28
                     current_state <= carica_stringa;</pre>
29
                  end if;
30
         when carica_stringa=> current_state<=shifting;</pre>
31
         when shifting=> current_state<=riconosci_bit;</pre>
32
         when riconosci_bit=> if i=std_logic_vector(to_unsigned(width, n'length)
33
             ) then
                            current state <= idle;
34
                         elsif data(to_integer(unsigned(i))) = data_in then
35
                            current state <= shifting;
36
                         elsif data(to_integer(unsigned(i)))/=data_in then
37
                            current state <= idle;
38
                         end if;
39
       end case;
40
       end if;
41
     end process;
42
     recognize_bit: process(clk,current_state,i,data_in,start)
43
      begin
44
      shift<='0';
45
      correct<='0';
46
      bad<='0';
47
      en_c<='0';
48
      en i<='0';
49
      en res<='0';
50
       case current state is
51
         when idle =>
52
            shift<='0';
53
            --n<=std_logic_vector(to_unsigned(width, n'length));
54
            if start='1' then
55
              correct<='0';
56
              bad<='0';
57
              en_i<='1';
58
              shift<='1';
59
              --next_state<=shifting;
60
            end if;
61
         when carica_stringa =>
62
              en_i<='0';
63
         when shifting =>
64
              en i<='1';
65
              shift<='0';
66
              en c<='0';
67
              --next state<=riconosci bit;
68
         when riconosci_bit =>
69
              en_i<='1';
70
              if i=std_logic_vector(to_unsigned(width,n'length)) then
71
              correct<='1';
72
              en_res<='1';
73
              --next_state<=idle;
74
              elsif data(to_integer(unsigned(i))) = data_in then
75
```

```
en_c<='1';
76
                shift<='1';
77
               --next_state<=shifting;
78
               else
79
               bad<='1';
               en res<='1';
81
               --next_state<=idle;
82
83
               end if;
        end case;
84
     end process;
85
   end Behavioral;
86
```

Codice Componente 7.1: Definizione della macchina a stati finiti

Notiamo che tutti i segnali di uscita, per le varie abilitazioni, come lo shifting o l'abilitazione dei conteggi vengono fissati ad un valore ben preciso prima del case all'interno del secondo process, questo per far si che il sintetizzatore, non rilevi dei latch durante la sua esecuzione, (ciò può essere dovuto al fatto che i segnali non essendo fissati in dei registri il sintetizzatore vuole salvarli così da poter effettuare una corretta sintesi del codice, questo vale anche per le altre macchine a stati finiti sviluppate successivamente).

| Di seguito vengono riportati i differenti risultati operativi nel caso in cui si utilizzir | o diverse |
|--------------------------------------------------------------------------------------------|-----------|
| codifiche di rappresentazione degli stati si una macchina a stati finiti.                  |           |

| Codifica   | Numero di slice | Numero di flip flop | Numero di four lut | Frequenza massima |
|------------|-----------------|---------------------|--------------------|-------------------|
| One-hot    | 19              | 16                  | 37                 | 184.805MHz        |
| Speed1     | 19              | 16                  | 37                 | 184.805MHz        |
| Compact    | 15              | 14                  | 29                 | 191.031MHz        |
| Sequential | 15              | 14 mm               | 29                 | 191.031MHz        |
| Gray       | 17              | 14                  | 31                 | 180.665MHz        |
| Johnson    | 17 // 🔎         | 7° 14 /\=\          | 31                 | 180.665MHz        |

Dato il numero di stati molto ridotto, i risultati ottenuti utilizzando le varie codifiche in alcuni casi sono risultati perfettamente gli stessi, le codifiche che hanno dato gli stessi risultato sono state messe una successivamente all' altra, difatti notiamo che One-hot e Speed1 ottengono gli stessi risultati, facendo riferimento alla manuale di XST di Xilinx la codifica Speed1 è orientata alla velocità ma i bit usati per identificare lo stato di solito sono in numero maggiore al numero degli stati della macchina, quindi il sintetizzatore alla fine si riconduce alla codica One-hot ed è quello che occupa maggior area, dato che utilizza un singolo flip flop per codificare ogni stato quindi la sua velocità al crescere degli stati e indipendete, anche se l' area occupata crescerà linearmente con il numero di stati;

compact è quella che richiede meno spazio cerca di utilizzare il minore numero di bit possibili per codificare gli stati, in questo caso risulta la più efficiente, perchè oltre ad essere minore lo spazio occupato essendo il numero di stati davvero esiguo il tutto riesce ad essere mappato in slice presenti nella stessa CLB, rendendo la frequenza massima operativa maggiore;

Sequential utilizzato un approccio radix-two sugli stati presenti su path molto lunghi, ma in questo caso ci si riconduce ad una soluzione compact essendo gli stati solo due;

Gray permetteno di far variare un solo bit alla volta occupa lo stesso spazio della compact, ma la logica combinatoriale per far variare tra gli stati e più complessa ed implica anche una minore frequenza operativa, per rendere sicuro il cambio di stato; Johnson comunque permette la variazione di un solo bit alla volta, ma in questo caso coincide con la codifica di gray, anche se di solito i bit per la rappresentazione sono maggiori.

## 7.3 Simulazione



Figura 7.2: Stringa riconosciuta correttamente





Figura 7.3: Stringa non riconosciuta

Nei due esempi: in alto, viene mostrato un caso in cui la stringa da riconoscere è quella in ingresso sono le stesse in basso invece, in cui le due stringhe sono dissimili.

## 7.4 Sintesi su board FPGA

```
entity tester_dispositivi is
1
       Port ( clock : in STD_LOGIC;
2
           button : in STD_LOGIC_VECTOR (3 downto 0);
3
           led : out STD_LOGIC_VECTOR (7 downto 0);
              in_byte : in STD_LOGIC_VECTOR (7 downto 0));
5
  end tester_dispositivi;
6
  architecture Behavioral of tester_dispositivi is
  COMPONENT contatore_modulo_2n
    PORT (
10
       clk : IN std_logic;
11
       enable : IN std_logic;
12
       reset : IN std_logic;
13
       hit : OUT std_logic;
14
       output : OUT std_logic_vector(1 downto 0)
15
       );
16
    END COMPONENT;
17
    component latch_d_en is
18
    generic(width:natural:=8);
19
       Port ( clk : in STD_LOGIC;
20
```

```
reset : in
                           STD_LOGIC;
21
               en : in
                       STD_LOGIC;
22
               d: in
                       STD_LOGIC_VECTOR (width-1 downto 0);
23
                        STD_LOGIC_VECTOR (width-1 downto 0));
24
     end component;
25
     COMPONENT riconoscitore_stringa_generico
26
     PORT (
27
28
       clk: IN std logic;
       reset : IN std_logic;
29
       start : IN std logic;
30
       data : IN std_logic_vector(7 downto 0);
31
       stringa : IN std_logic_vector(7 downto 0);
32
       bad : OUT std_logic;
33
       correct : OUT std_logic
34
       );
35
     END COMPONENT;
36
     COMPONENT display_top_level
37
     PORT (
38
       clock : IN std_logic;
39
       reset : IN std_logic;
40
       load_conf : IN std_logic;
41
       load_value : IN std_logic;
42
       number : IN std_logic_vector(15 downto 0);
43
       in_byte : IN std_logic_vector(7 downto 0);
44
       anodes : OUT std_logic_vector(3 downto 0);
45
       cathodes : OUT std_logic_vector(7 downto 0)
46
       );
47
     END COMPONENT;
48
     COMPONENT debounce
49
     PORT (
50
       clk : IN std_logic;
51
       button : IN std_logic;
52
       result : OUT std_logic
53
54
       );
     END COMPONENT;
55
     signal sel :STD_LOGIC_VECTOR(1 downto 0):=(others=>'0');
56
     signal scelta: STD_LOGIC_VECTOR( 3 downto 0):=(others=>'0');
57
     signal value:STD LOGIC VECTOR(15 downto 0) := (others=>'0');
58
     signal en_c,en_ric,hit,en_c1,reset_c,bad,correct:STD_LOGIC:='0';
59
   begin
60
     deb:debounce port map(clock, button(0), en_c);
61
     change: process (clock,en_c)
62
     begin
63
     if rising_edge(clock) then
64
       if en_c='1' then
65
         case sel is
66
           when "00" => scelta<="0001";
67
           when "01" => scelta<="0010";
68
           when "10" => scelta<="0100";</pre>
69
```

```
when "11" => scelta<="1000";
70
            when others => scelta<="1111";
71
          end case;
72
       else
73
          scelta<="0000";
74
       end if;
75
     end if;
76
     end process;
77
     selettore: contatore_modulo_2n port map(en_c,'1',not(button(3)),open,sel)
78
     data : latch_d_en port map(clock, not(button(3)), scelta(1), in_byte(7 downto
79
          0), value (7 downto 0));
     stinga : latch_d_en port map(clock,not(button(3)),scelta(2),in_byte(7
80
         downto 0), value(15 downto 8));
     counter: contatore_modulo_2n port map(clock,en_c1,reset_c,hit,open);
81
     st: process(scelta, clock, hit)
82
       begin
83
       reset_c<='1';
84
          if scelta(3)='1' and hit='0' then
85
            en_ric<='1';
86
            en c1<='1';
          elsif scelta(3)='1' and hit='1' then
88
            en c1<='0';
89
            en ric<='0';
90
91
            reset c<='0';
92
          end if;
93
       end process;
94
     led(7) \le sel(1);
95
     led(6) \le sel(0);
96
     led(0) <=correct;</pre>
97
     led(1) <= bad;
98
     ric_stringa_generico : riconoscitore_stringa_generico port map(clock, not(
99
         scelta(0)),en_ric,value(7 downto 0),value(15 downto 8),bad,correct);
   end Behavioral;
100
```

Codice Componente 7.2: Definizione del componente che gestisce il caricamento dei dati

Il codice mostrato descrive un tester utilizzato, con piccole differenze dove occorre, utilizzato per tutti i dispositivi non solo combinatoriali presenti in tale elaborato, difatti al suo interno è presente un process che genera un segnale di start attivo fino a quando il contatore al di sopra di esso non termina, questo perchè tale segnale non deve essere attivo continuamente altrimenti i dispositivi ricomincerebbero a computare non appena tornerebbero nello stato di riposo, ma deve essere attivo per un tempo tale affinchè venga rilevato dal dispositivo che deve essere avviato.

Vengono utilizzati gli switch per inserire sia la stringa da riconoscere, oltre a quella con cui si deve effettuare il confronto, tali valori sono sorretti da registri;

il led zero si attiva se il riconoscimento è andato a buon fine, il led uno nel caso contrario;

i led sei e sette occorrono a determinare: quali registri per contenere i dati si sono selezionati (se acceso il led sei il dato da voler confrontare, se acceso il sette la stringa da riconoscere), se si è avviata la computazione (entrambi i led accesi) o nel caso in cui sono spenti entrambi venga effettuato il reset del dispositivo per effettuare una successiva computazione;

il reset degli altri componenti invece è abilitato della pressione del pulsante tre, invece il pulsante zero permette la selezione dei registri e l'avvio della macchina a stati finiti;

per caricare i dati gli switch devono essere impostati prima che il led relativo al registro venga acceso, vale anche per gli altri tester utilizzati.



## Ripple Carry

### 8.1 Traccia

Realizzare un'architettura di tipo Ripple Carry per un sommatore ad N bit generico. Il circuito deve essere realizzato a partire da blocchi di Full Adder, espresso mediante porte logiche XO-R/AND/OR. Riportare considerazioni sull'area occupata e sul tempo di calcolo al variare di N e commentare il risultato con le formule teoriche.

## 8.2 Soluzione

#### 8.2.1 Schematici



Figura 8.1: Ripple Carry Adder

Per realizzare il circuito si è ricorsi al costrutto for generate, per colleggare i vari full adder per far sì che i riporti generati dal full adder precedente vengano propagati al successivo, purtroppo dallo schematico non è evidente, perché i costrutti di questo tipo quando viene chiesto ad ISE di creare lo schematico non lo espande mostrando tutti i singoli full\_adder, ma ne crea uno solo che però ha in ingresso ed uscita un vettore di bit.

| Numero di bit operandi | Numero di slice | Numero di four LUT | Tempo di calcolo |
|------------------------|-----------------|--------------------|------------------|
| 4                      | 6               | 8                  | 7,225  ps        |
| 8                      | 12              | 16                 | 7,735  ps        |
| 16                     | 24              | 32                 | 9,358  ps        |
| 32                     | 48              | 64                 | 9,985  ps        |

Secondo le formule dell' area e del ritardo, l' area è pari a 5n (dove n indica il numero di fulladder), ed  $2\delta n$  per il ritardo, la realizzazione per FPGA invece presenta dimensioni e ritardi diversi, difatti l' area raddoppia se raddoppiano il numero di bit per la somma, molto probabilmente perché utilizzerà ogni slice come un full adder, invece il tempo di calcolo all' aumentare del numero di bit cresce ma meno che linearmente, determinante dal fatto che il sintetizzatore riuscirà a disporre le slice molto vicine tra di loro e il tempo di propagazione dei riporti diverrà molto piccolo, si nota però che da 8 a 16 bit il tempo di calcolo incrementa di una quantità maggiore rispetto al passaggio da a 4 a 8 o da 16 a 32, perchè le connessioni non avvengono tra CLB vicini tra loro, per determinare il tempo si è scelto come input sempre il massimo valore accettabile in ingresso.

Non è stato possibile testare il componente con numero di bit di operandi a 64 bit, poichè quando si cerca di mappare sulla scheda i vari pin di ingresso e di uscita dell' addizionatore, questa operazione non riesce, una soluzione sarebbe quella di evitare che I/O venga mappato, però ISE ci avverte che i tempi di propagazione potrebbero essere non veritieri, allora si potrebbe utilizzare un altro componente per far passare gli input non contemporaneamente all' addizionatore, ma l' area del dispositivo verrebbe influenzata da tutte le connessioni che occorrono per questo dispositivo e ci potrebbero essere delle ottimizzazioni che minimizzano l' area.

#### **8.2.2** Codice

Ripple Carry Adder ISE

## 8.3 Simulazione



Figura 8.2: Ripple Carry Adder esempio di somma

## 8.4 Sintesi su board FPGA

Per la sintesi si è utilizzato un tester simile a questo 7.4, con la differenza che non vi è un process per la gestione dello start, essendo il componente da testare combinatoriale, gli switch occorrono per l'inserimento degli operandi i led sette, sei e cinque indicano, nel caso in cui il led cinque o il led sei sia acceso che abbiamo selezionato un registro per caricare i dati, se sono accesi entrambi stiamo assegnando il valore uno al carry in ingresso, se si abilita il led sette utilizziamo l'addizionatore come sottrattore, mentre l'accensione del led zeo determina se è presente il carry in uscita o meno, quella del led uno che vi è una situazione d'errore dovuta al sottrattore, a dispetto del tester messo in riferimento, qui viene anche utilizzato il display per visualizzare il risultato, per decidere quante cifre del display vogliamo utilizzare basta abilitare gli ultimi quattro switch (a partire dal quinto all'ottavo questi mettono in funzione dalla prima alla quarta cifra) e premere il pulsante due, se abbiamo bisogno dei punti questi vengono abilitati dai primi quattro switch (stesso ragionamento fatto per le cifre) dopodichè bisogna sempre premere il pulsante due, per visionare la somma bisogna premere il pulsante uno.

# Carry Look Ahead

## 9.1 Traccia

Realizzare un'architettura di tipo Carry Look Ahead per un sommatore ad 8 bit. Il circuito deve essere realizzato a partire dai blocchi:

- 1. Propagation/Generation calculator
- 2. Carry Look-Ahead
- 3. Full Adder



## 9.2 Soluzione

#### 9.2.1 Schematici



Figura 9.1: Carry Look a Head

L'addizionatore è costituito, da una rete che permette di calcolare i riporti generati e propagati (vengono utilizzati una serie di half adder per ogni coppia di bit), questi poi vengono propagati ad una rete Carry Look A Head che contemporaneamente combina i riporti ricevuti, altrimenti ci si riconducerebbe al caso Ripple Carry, dopodiché il riporto generato dalla rete Carry Look A Head viene messo in ingresso ad un XOR insieme al ritardo propagato, calcolato precedentemente.

| Numero di bit operandi | Numero di slice | Numero di four LUT | Tempo di calcolo     |  |
|------------------------|-----------------|--------------------|----------------------|--|
| 4                      | 6               | 8                  | $7{,}190 \text{ ps}$ |  |
| 8                      | 12              | 7 19               | 7,444 ps             |  |
| 16                     | 24              | 32                 | 9,006  ps            |  |
| 32                     | 48              | 64                 | $9{,}139 \text{ ps}$ |  |

Secondo le formule dell' area e del ritardo, l' area è pari a  $(n^2 + 9n)/2$  volte(dove n indica il numero di porte logiche), ed 5/delta, ma se confrontiamo i risultati con quelli ottenuti sintetizzando il Ripple Carry Adder 8.2.1, possiamo osservare che trascurando il caso 8 bit, l' area occupata è pressoché la stessa, ma i tempi di calcolo sono sensibilmente minore, aiutando ad affermare con certezza che sulla nostra FPGA tale soluzione risulta migliore.

#### 9.2.2 Codice

Carry Look A Head ISE

#### 9.2.2.1 Carry Look A Head

```
entity Carry_Look_A_head_r is
     generic(width: Natural :=8);
2
      Port ( c_generate : in STD_LOGIC_VECTOR (width-1 downto 0);
3
              c_propagate : in STD_LOGIC_VECTOR (width-1 downto 0);
              cin : in STD_LOGIC;
5
              cout : out
                          STD_LOGIC_VECTOR(width downto 1));
  end Carry_Look_A_head_r;
  architecture Structural of Carry_Look_A_head_r is
    COMPONENT Carry_Look_A_head_unit
10
    generic(width: NATURAL:=8);
11
    PORT (
12
      c_generate : IN std_logic_vector(width-1 downto 0);
13
       c_propagate : IN std_logic_vector(width-1 downto 0);
14
      cin : IN std_logic;
15
      cout : OUT std_logic:='0');
16
    END COMPONENT;
17
  begin
18
    C_L_A: for i in 1 to width generate
19
       inst_C_L_A_U: Carry_Look_A_head_unit generic map (width=>i) port map(
20
          c_generate(i-1 downto 0),c_propagate(i-1 downto 0),cin,cout(i));
    end generate;
21
  end Structural;
22
```

Codice Componente 9.1: Definizione del Carry Look a Head

Del Carry Look a Head ne viene generato uno di una dimensione pari al numero di riporti propagati e generati da gestire.

## 9.3 Simulazione



Figura 9.2: Carry Look a Head esempio di somma

## 9.4 Sintesi su board FPGA

Valgono le stesse considerazioni fatte per il Ripple Carry Adder 8.4.

# Carry Save

## 10.1 Traccia

Realizzare un esempio di addizionatore basato sulla modalita Carry Save.

## 10.2 Soluzione

### 10.2.1 Schematici



Figura 10.1: Carry Save Adder

Si è scelto di realizzare un semplice addizionatore di tipo carry save che effettua la somma di due operandi da tre bit, nello schematico sono mostrati due carry save cell, queste sono formate da due full adder, uno utilizzato come carry save ed un altro come un full adder, dopodiché i valori calcolati dal primo carry save cell vengono propagati al secondo (viene propagato il riporto del full adder), mentre il valore di somma del secondo carry save presente nella seconda cella (carry save cell) viene messo in ingresso al full adder della prima e la somma è determinata dalle uscite dei full adder, più l' uscita della somma del primo carry save.

#### 10.2.2 Codice

Carry Save Adder ISE

#### 10.2.2.1 Carry Save Cell

```
entity carry_save_cell is
       Port ( adder : in
                           STD_LOGIC_VECTOR (2 downto 0);
2
              cin_full_a: in STD_LOGIC;
3
           temporary_f_a:in STD_LOGIC;
           temporary_c_s : out STD_LOGIC;
5
              cout : out
                           STD_LOGIC;
6
              sum : out
                          STD_LOGIC);
  end carry_save_cell;
  architecture structural of carry save cell is
10
  component full adder half is
11
       PORT ( A: in STD_LOGIC;
12
         B: in STD_LOGIC;
13
         CIN: in STD_LOGIC;
14
         S: out STD LOGIC;
15
         COUT: out STD_LOGIC
16
       );
17
  end component;
18
  signal c0:STD_LOGIC:='0';
19
  begin
20
    carry_save:full_adder_half port map(adder(0), adder(1),adder(2),
21
        temporary_c_S,c0);
     full_adder:full_adder_half port map(c0,cin_full_a,temporary_f_a,sum,cout);
22
23
  end structural;
```

Codice Componente 10.1: Definizione della carry save cell

Come è realizzata una cella carry save citata sopra.

## 10.3 Simulazione



Figura 10.2: Carry Save Adder

## 10.4 Sintesi su board FPGA

Valgono le stesse considerazioni fatte per il Ripple Carry Adder 8.4, eccezione fatta per gli switch che ne vengono utilizzati solo sei invece di otto, (tre per un operando e tre per un altro, sono i primi sei a partire da destra), il led cinque è disabilitato non avendo la bisogno di provare anche quando il carry in ingresso è alto e la sottrazione viene effettuata quando led sette e 6 sono alti.



# Carry Select

### 11.1 Traccia

Realizzare un sommatore Carry Select generico ad N bit. Il circuito deve essere realizzato a partire da blocchi di Full Adder, espresso mediante porte logiche XOR/AND/OR. Riportare considerazioni sull'area occupata e tempo di calcolo al variare di N e commentare il risultato con le formule teoriche.

## 11.2 Soluzione

#### 11.2.1 Schematici

Il sommattore essenzialmente è costituito da un numero di carry select cell, di dimensione identiche (è possibile scegliere la dimensione della cella) che calcolano le somma parziali e propagano i riporti alle celle successive, il numero di celle da istanziare è data dalla dimensione della cella e dal numero di bit su cui viene effettuata la somma, una cella è costituita da due Ripple Carry Adder uno avente carry in ingresso pari ad uno ed un altro pari a zero, di seguito si determinano valori caratteristici del sommatore considerando una carry select cell di dimensione pari a quattro bit.



Figura 11.1: Carry Select Adder

| Numero di bit operandi | Numero di slice | Numero di four LUT | Tempo di calcolo |  |
|------------------------|-----------------|--------------------|------------------|--|
| 4                      | 5               | 10                 | 6,853  ps        |  |
| 8                      | 12              | 21                 | 7,467  ps        |  |
| 16                     | 24              | 43                 | 8,521  ps        |  |
| 32                     | 48              | 87                 | 9,984  ps        |  |

Confrontando i risultati con il sommatore Ripple Carry Adder, 8.2.1 il numero di slice occupate è pressochè lo stesso tranne nel primo caso, invece il numero delle LUT è maggiore, dovute alle interconnessioni che permettono ai Ripple Carry Adder di avere carry in ingresso pari ad uno o zero e a quelle per collegare i vari carry in uscita. I tempi di calolo sono migliori in tutti i casi tranne che nell'ultimo che sono pressoché gli stessi, l'uguaglianza del tempo di calcolo nell'ultimo caso con quello del Ripple Carry Adder è dovuto che il carry select avendo una cella di dimensione quattro all'aumentare del numero di operandi, aumentano il numero di celle istanziate, il tempo di attesa dell'ultima cella diventa sempre maggiore e tende ad essere comparabile con quello di un Ripple Carry Adder, difatti anche se i vari sommattori stanno funzionando in parallelo, i vari selettori che decidono quali risultati dare in uscita, devono attendere il carry proveniente dal blocco precedente ed all'aumentare dal numero di blocchi, il beneficio di avere tanti sommatori va diminuendo, se la dimensione dei blocchi non viene ottimizzata.

## 11.2.2 Codice

Carry Select Adder ISE

## 11.3 Simulazione



Figura 11.2: Carry Select Adder

## 11.4 Sintesi su board FPGA

Valgono le stesse considerazioni fatte per il Ripple Carry Adder 8.4.



## Addizionatore a 7 operandi

### 12.1 Traccia

Progettare in VHDL un sommatore ad N bit capace di sommare 7 operandi. Il risultato della somma deve essere completo senza overflow, cio'e la somma in uscita deve essere espressa su un numero di bit tali da consentire il non verificarsi di condizioni di overflow. Nel caso specifico i bit in uscita devono essere pari ad N+3. Il progetto pu'o essere realizzato mediante composizione di Full Adder. Per ciascuna colonna si pu'o effettuare un conteggio, producendo in uscita un valore binario espresso su 3 bit. Tenendo conto della posizione dei riporti un sommatore (e.g. ripple carry) pu'o sommare tutti i riporti generati, restituendo il risultato finale. I riporti generati possono propagarsi sino alla cifra i+2 (e.g. la somma di 5 volte 1 genera 1 con riporto 10). Eventuali altre cifre binarie, come i riporti generati da somme precedenti, vanno considerati: quindi si verifica che un riporto pu'o generarsi fino alla i+4-esima cifra binaria.

## 12.2 Soluzione

#### 12.2.1 Schematici



Figura 12.1: Seven Operand Adder

L'addizionatore è costituito dapprima da un dispositivo che trasforma i sette input in ingresso in soli tre input da nove bit ognugno, grazie al componente seven to three il quale conta il numero di uno presenti in ingresso, di questi ne sono presenti otto ed ognugno ha in ingresso bit dello stesso peso appartenenti a ciascuno operando, i valori in uscita di tali componenti prima di essere passati al successivo vengono incolonnati introducendo degli zero fittizzi per fa sì che le tre stringhe di bit in uscita abbiano lo stesso peso(se pensiamo al primo seven to three genera un bit di peso zero, uno di peso uno e l'ultimo di peso due, questi vanno associati a tre strighe diverse ma le stringhe con il bit di peso uno e due hanno bisogno di zero antecedenti per poter incollonare le somme). Il partial sum due non sono altro che dei full adder utilizzati come carry save, per produrre due stringhe che vengono fatte sommare da dei Ripple Carry Adder, facendo le stesse considerazione sui pesi discusse nel passo precedente.

#### 12.2.2 Codice

Seven Adder ISE

## 12.3 Simulazione



Figura 12.2: Seven Adder esempio di somma

## 12.4 Sintesi su board FPGA

Valgono le stesse considerazioni fatte per il Ripple Carry Adder 8.4, con la differenza che ci sono sette registri da poter caricare.

## Moltiplicatori

## 13.1 Traccia

### 13.1.1 Moltiplicatore a celle Mac

Realizzare in VHDL un circuito di moltiplicazione a celle MAC di N bit. La cella MAC deve contenere un Full Adder (descritto gi'a in esercizi pre- cedenti) ed una porta AND per la moltiplicazione parziale. Tale cella deve essere replicata in una struttura ordinata (per righe e colonne) per comporre il circuito intero di moltiplicazione. Effettuare considerazioni di occupazione di area e di tempi di propagazione dei segnali al variare di N per valori significativi, apportando eventuali commenti salienti.

## 13.1.2 Moltiplicatore di Booth

Realizzare in hardware l'algoritmo della moltiplica- zione secondo Booth per operandi ad 8 bit. L'architettura deve essere rea- lizzata sulla base dello schema di progettazione PO/PC (Parte Operativa e Parte di Controllo).

## 13.2 Soluzione

#### 13.2.1 Schematici

#### 13.2.1.1 Moltiplicatore a celle Mac



Figura 13.1: Mac Multiplier

Viene mostrato un esempio di moltiplicatore a celle MAC 2x2 (purtroppo lo schematico se preso nella sua interezza non rendeva visibili i segnali), per la gestione dei segnali di interconnessione si è ricorso all' uso di un costrutto matrix, data la simmetria del circuito in cui vengono gestiti i vari carry e somme parziali di ingresso ed uscita, si è scelto di instanziare prima le righe, gestendo le somme parziali in ingresso ed in carry in uscita, alla successiva riga invece vanno gestiti i carry in ingresso e le somme in uscita.

| Numero di bit | Numero di slice | Numero di four LUT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Tempo di calcolo | Tempo di    |
|---------------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|-------------|
| operandi      |                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                  | calcolo per |
|               |                 | 5/Y6/\$\\\                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                  | cel-        |
|               | 140             | DECEMBER OF THE PARTY OF THE PA | 0-,//            | la(stimato) |
| 2x2           | 4               | 8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 8,978 ps         | 1,122 ps    |
| 4x4           | 17              | 32                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 14,557 ps        | 0,7278  ps  |
| 8x8           | 65              | 128                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 25,026  ps       | 0.579  ps   |
| 16x16         | 256             | 512                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 51,175 ps        | 0,556  ps   |

Possiamo riscontrare che il sintettizzatore, mette in ogni slice una cella MAC, lo spazio occupato quindi per ogni raddoppio di riga e di colonna diventa quattro volte maggiore come anche il numero di LUT quadruplica, per il numero minimale di slice presente sulla BASYS non è possibile sintetizzare un 32x32.

I tempi di calcolo teoricamente dovrebbero essere pari a 6(n-1)T + 2T (dove n numero o di riga o di colonna essendo il moltiplicatore simmettrico e T ritardo di una porta), se dalla formula ricaviamo T al variare di n notiamo che il tempo per cella descresce, in realtà le celle vengono messe sempre più vicine durate l' operazione di place and routing, dato che il loro numero aumenta e lo spazio diminuisce, riducendo così la distanza fra di esse ed il tempo di propagazione dei segnali.

#### 13.2.1.2 Moltiplicatore di Booth



Figura 13.2: Booth Multiplier

Per realizzare il motiplicatore (che utilizza la codifica Booth-1), si è utilizzato una macchina a stati finiti con i seguenti stati:

- idle, stato in cui la macchina non opera; init, vi è l' inizializzazione dei registri e delle scan chain, il moltiplicatore va salvato in un registro, nella scan chain q il moltiplicando e a viene settata a 0;
- in getseq vengono letti gli ultimi due bit in uscita dalla scan chain q, in base ai valori ne si ricava la codifica di Booth e si decide se sommare, sottrarre prima di effettuare lo shifting o solo effettuare quest' ultimo;
- in inits si abilita lo shifting che verrà effettuato al passaggio nel successivo stato shift.

Le scan chain utilizzata per questo progetto e per gli altri dispositivi sequenziali non è quella mostrata nel paragrafo 6.2, in particolare è stato aggiunto un secondo segnale di abilitazione en oltre a scan\_en: il primo, permette di scegliere cosa shiftare se l' ingresso din oppure un valore già precedentemente shiftato, difatti viene sfruttato nel caso in cui avvenga una somma o una

sottrazione, perchè prima di fare lo shiting viene caricato il risultato di tale operazione in a e poi shiftato, se avessi utilizzato la semplice scan chain ogni volta che scan\_en sarebbe stato attivo avrei shiftato il valore presente nel registro, oppure avrei shiftato sempre il valore della somma messa in ingresso nella semplice scan chain, invece in alcuni casi non voglio shiftare il risultato dell' addizione. La terminazione si ha quando il contatore genera un segnale di hit, che avviene successivamente all' ultima operazione derivante dalla codifica di Booth.

#### 13.2.2 Codice

Mac ISE

Booth ISE

#### 13.2.2.1 Moltiplicatore a celle Mac

```
entity mac_multiplier is
1
     generic(
2
       N : natural := 2;
3
       M : natural := 2
    );
5
     port (
       a : in std_logic_vector(N-1 downto 0);
       b : in std_logic_vector(M-1 downto 0);
       s_in : in std_logic_vector(N-1 downto 0);
       c_in : in std_logic_vector(M-1 downto 0);
10
       ris : out std_logic_vector(M+N-1 downto 0)
1.1
     );
12
   end mac_multiplier;
13
14
   architecture structural of mac_multiplier is
15
16
   component mac_cell is
17
     port (
18
       x : in std_logic;
19
       y : in std_logic;
20
       c_in : in std_logic;
21
       s_in : in std_logic;
22
       c_out : out std_logic;
23
       s_out : out std_logic
24
     );
25
   end component;
26
27
   type matrix is array(M downto 0, N downto 0) of std_logic;
28
   signal carry : matrix := (others => (others => '0')); -- riga M non usata
29
   signal partial_sum : matrix := (others => (others => '0'));-- (0,0) non
30
      usato
31
  begin
32
     inizializza_carry : for i in 0 to M-1 generate
33
```

```
carry(i,0) \ll c_in(i);
34
    end generate;
35
    inizializza_sum : for j in 0 to N-1 generate
36
      partial_sum(0, j+1) \le s_in(j);
37
    end generate;
38
39
    --partial_sum(1 to M,N) <= carry(0 to M-1, N);
40
    --ris <= partial_sum(M,N downto 0) & partial_sum(M-1 downto 1,0); strongly
41
         typed
    mac_matrix : for i in 0 to M-1 generate -- si genera una riga per tutte le
42
         colonne si gestiscono le somme parziali e i carry in uscita
      mac_row : for j in 0 to N-1 generate -- dopodichÚ si procede alla
43
          successiva riga
        mac : mac_cell
44
           port map (
45
             x => a(j), -- posiziona i bit di un operando sulla colonna
46
             y => b(i), -- posiziona i bit di un operando su una righa
47
             c_in => carry(i,j),-- i carry in ingresso di uno stadio precedente
48
                 per i primi mac di riga e colonna pari a 0
             s_in => partial_sum(i,j+1), -- somma parziale ottenuta da uno
49
                stadio precedente
             c_out => carry(i,j+1), -- carry in uscita per la prossima cella
50
             s_out => partial_sum(i+1,j) -- somma in uscita per il successivo
51
                carry
           );
52
      end generate;
53
      partial_sum(i+1,N) <= carry(i,N); -- riporto i carry in uscita presenti
          all' ultima colonna di ogni riga come somma parziale in ingresso
      ris(i) <= partial_sum(i+1,0); -- i primi bit della moltiplicazione
55
          risultano dalla somma parziale in uscita dai primi elementi in
          colonna di ogni riga
    end generate;
56
57
    risultato_completo : for z in 1 to N generate
58
       ris(z+M-1) <= partial_sum(M,z); -- gli ultimi valori di prodotto sono
59
          dati dai valori di somma partiale dell' ultima riga
    end generate;
60
  end structural;
61
```

Codice Componente 13.1: Definizione della carry save cell

## 13.3 Simulazione



Figura 13.3: Esempio di moltiplicazione a celle Mac



Figura 13.4: Esempio di moltiplicazione utilizzando Booth

## 13.4 Sintesi su board FPGA

### 13.4.0.1 Moltiplicatore a celle MAC

Valgono le stesse considerazioni fatte per il Ripple Carry Adder 8.4, però i led zero, uno e cinque non vengono utilizzati ed i vari segnali di abilitazione sottrazione e carry non sono presenti.

#### 13.4.0.2 Moltiplicatore di Booth

Valgono le stesse considerazione per il riconoscitore di stringhe 7.4, dove l'accensione del led zero indica la fine dell'operazione, il led uno non viene utilizzato mentre invece il display è impiegato come in 8.4.

# Divisori

## 14.1 Traccia

Realizzare in hardware l'algoritmo della divisione Restoring per operandi ad 8 bit. L'architettura deve essere realizzata sulla base dello schema di progettazione PO/PC (Parte Operativa e Parte di Controllo).



## 14.2 Soluzione

#### 14.2.1 Schematici



Figura 14.1: Divisore restoring

Il circuito è molto simile a quello utilizzato per sviluppare un moltiplicatore di Booth 13.2.1.2, cambia radicalmente però in che modo i bit vengono trattati difatti la macchina a stati finiti consiste di sei stati:

- idle stato di riposo, attende il segnale di avvio di una computazione;
- init, in cui avviene l'inizializzazione delle scan chain, in questo caso q ed r (q caricato con il valore del dividendo ed r inzializzato a 0) e un registro per salvare il valore del divisore;
- shift in cui i dati ( q ed r ) vengono shiftati a sinistra ( in Booth i dati shiftano a destra);
- sub in cui viene effettuata la sottrazione, nel caso il risultato sia un numero negativo si ritorna in shift altrimenti, si procede nello stato set\_1 che setta ad uno il bit da dover shiftare all' interno di q, tale shift avverrà nello stato shift1.

Il segnale di terminazione della computazione viene attivato quando il contatore segnala un numero di operazioni pari al numero di bit del dividendo.

#### 14.2.2 Codice

Divisore Restoring ISE

## 14.3 Simulazione



Figura 14.2: Esempio divisione

Il quoziente ed il resto vengono espresse in un unica stringa da 16 bit dove la metà superiore della stringa è il quoziente la metà inferiore il resto, questo per facilitare successivamente la scrittura sul display.

## 14.4 Sintesi su board FPGA

Valgono le stesse considerazione per il riconoscitore di stringhe 7.4, dove l'accensione del led zero indica la fine dell'operazione ed il led uno non viene utilizzato, viene caricato prima il dividendo e poi il divisore, infine le prime due cifre del display indicano il quoziente le seconde il resto ed è utilizzato come descritto qui 8.4.



## **UART**

## 15.1 Traccia

Realizzare un dispositivo VHDL che implementa il protocollo UART (a partire da quello diffuso dalla Digilent). Collegare internamente, oppure tramite inter- faccia fisica esterna alla board stessa, ad un'altra board oppure ad un PC previo utilizzo di un physical RS232, due interfacce per trasmette e ricevere ottetti. Svolgere l'esercizio riutilizzando il VHDL messo a disposizione da Digilent (e disponbile nel materiale del corso) commentando eventuali ristrutturazioni del codice. (Opzionale) Sviluppare un'architettura per l'implementazione del protocollo UART secondo il paradigma PO/PC ex-novo, evidenziando le similarit'a/dissimilarit'a con il progetto Digilent.



## 15.2 Soluzione

#### 15.2.1 Schematici



Figura 15.1: UART

Si è realizzata una versione di UART secondo lo schema PO/PC, i componenti principali solo le due macchine a stati finiti:

- il trasmitter che consiste di cinque stati:
  - idle, rimane in attesa fino a che non si decide di avviare una trasmissione;
  - send start invia il segnale di start;
  - wait\_for\_next attende fino a che il contatore counter\_t non genera un segnale di counter hit, per far sì prima che venga inviata la successiva informazione, quella attuale venga sorretta per sedici colpi di clock;
  - send che abilita lo shifting della scan chain con il dato ingresso per invare il successivo bit;
  - send\_stop che invia il bit di stop, si abilita questo stato quando il numero di bit trasmetti è pari ad otto (il conteggio è fissato da un contatore).

- Il ricevitore invece è composto solo da quattro stati:
  - idle, si permane in questo stato fino a quando la linea dei dati in ingresso è alta;
  - sfasamento fa in modo di posizionare l' evento di lettura del dato a metà del tempo per il quale è sorretto il dato, così da essere sicuri di leggere correttamente il bit;
  - wait\_for\_next dove si attende per leggere il successivo bit;
  - receive dopo si effettua la lettura del bit in ingresso.

Il ricevitore ha diversi contatori, uno che tiene in conto del numero di bit letti affinchè dopo aver letto l' ottavo si ritorna in idle, un altro che conta il numero di cicli di clock per lo sfasamento ed infine uno che conta il numero di colpi di clock da attendere prima di leggere il successivo dato.

I dati in input ed in output sono sorretti da due scan chain come quelle utilizzate in Booth 13.2.1.2, quella dell' input è più grande di tre bit perchè vi è un primo bit alto per indicare che non vi è trasmissione di dati fino a che non vi è un invio di dati, il secondo è il bit di start ed il terzo messo in coda ai dati è quello di stop.

Premettendo che la soluzione di Digilent effettua vari controlli sulla trasmissione qui non effettuati, la riteniamo di non facile comprensione, scrivere in un unico file VHDL sia il ricevitore, trasmettitore, i contatori e tutti gli altri componenti a supporto non permette di rendere chiara la lettura, non è lampante quali parti siano a supporto del ricevitore e quali del ricevitore, non permettendo così una modifica veloce nel caso in cui volessimo attendere ad esempio trentadue cicli di clock prima di inviare ricevere un altro dato o estrapolare uno solo dei due componenti e riutilizzarlo (pensiamo al caso in cui dobbiamo solo inviare i dati e non riceverli), invece nella nostra soluzione possiamo estrapolare una delle due macchine a stati finiti all' occorrenza e nell' unico file in cui sono riacchiusi i componenti a corredo capire quali ci occorrono ed riutilizzarli, oppure in base ai segnali in ingresso alle due macchine sequenziali capire quali segnali ci possano occorrere, altro punto a sfavore è la realizzazione di diversi process per fare andare la macchina ad una frequenza voluta per trasmettere/ricevere ad un determinato baud rate, soluzione migliore consisterebbe di utilizzare un DCM e cambiare la frequenza in base alla necessità.

#### 15.2.2 Codice

UART ISE

## 15.3 Simulazione



Figura 15.2: UART

## **GPIO**

## 16.1 Traccia

Realizzare un dispositivo VHDL che implementa la logica three-state.

## 16.2 Soluzione

## 16.2.1 Schematico

#### 16.2.1.1 GPIO



Figura 16.1: GPIO Schematic

#### 16.2.2 Codice

Progetto ISE: GPIO ISE

#### 16.2.2.1 Pad

Questo componente, rappresentato in Figura 16.1 decide se l'operazione da effettuare è di scrittura o di lettura in base al valore del segnale di enable. Quando enable è alto, si effettua una scrittura e il segnale di input/output  $in\_out$  viene caricato con il valore del segnale di input, poi trasferito al segnale di output. Quando enable è basso si effettua un'operazione di lettura quindi, per evitare di disturbare il valore da leggere, viene spento il buffer, ponendo il segnale in\_out ad alta impedenza ('Z'). Questo comportamento è modellato tramite un costrutto dataflow with-select.

#### 16.2.2.2 GPIO

Questa è una top-level entity che si preoccupa di creare, tramite un for-generate, una serie di pad, il cui numero è settato tramite un generic.

Il componente in questione è osservabile a questo link: GPIO

Il componente in questione è osservabile a questo link: Pad

## 16.3 Sintesi su board FPGA

Questo dispositivo di GPIO è stato utilizzato per pilotare quattro led su una board Basys.

Facendo riferimento al codice presente al seguente link: GPIO Code, la sintesi di questo componente è stata realizzata facendo corrispondere al segnale di input/output pads, quattro pin di un 6-pin connectors; al segnale inputs i quattro switch meno significativi, per determinare l'accensione o lo spegnimento dei led; il segnale enable è stato collegato ai quattro switch più significativi, per abilitare la scrittura o la lettura dei valori di input ed infine il segnale outputs è stato collegato ai primi quattro degli otto led della board.



## Firma digitale

#### 17.1 Traccia

Realizzare un'architettura per la realizzazione di un sistema che effettui l'autenticazione di un messaggio a lunghezza variabile tramite l'algoritmo di crittografia RSA. Il sistema deve consentire di effettuare sia la fase di firma del messaggio, sia la fase di verifica del messaggio firmato.

### 17.2 Soluzione

#### 17.2.1 Schematici

Il seguente circuito implementa l'algortimo RSA per la firma di un messaggio, applica una funzione di hash sul messaggio e verifica che il messaggio ricevuto sia coretto.

L' intera procedura è divisa nelle seguenti fasi:

- vengono scelti i valori caratteristici per inviare il dato (p pari a 3, q 11, e 7 e d 3) ed il messaggio da inviare;
- si applica la funzione di hashing sul messaggio, utilizzando il metodo della moltiplicazione;
- viene applicata la firma sul messaggio originale utilizzando la chiave privata, il trasmettitore invia i due dati appena calcolati (anche se non è presente un vero e proprio invio essendo trasmettitore e ricevitore implementati sulla stessa board);
- Il ricevitore applica la chiave pubblica sul messaggio firmato, ne effettua l'hashing e verifica se la sua versione del messaggio a cui è stato applicato l'hashing è identico a quello che è stato ricevuto.

Così facendo garantiamo sia la segretezza (infatti non mandiamo il messaggio in chiaro), sia l'autenticazione (chi riceve il messaggio può verificare effettuando l'hashing con parametri convenuti non è stato modificato),

Di seguito vengono descritte le varie componenti che vengono utilizzate per effettuare l' hashing e firmare il messaggio.

#### 17.2.1.1 Funzione hash



Figura 17.1: hasher

Il circuito è stato realizzato in due differenti modi:

- nel primo caso si utilizza una macchina a stati finiti descritta da cinque stati:
  - idle, stato di riposo dell' automa;
  - init in cui si attende che il moltiplicatore termini il suo compito;
  - shifting r in cui il valore della moltiplicazione viene shiftato a destra;
  - shifting\_l il valore viene shiftato a sinistra; ended per comunicare la fine dell' operazione di hash;
- nel secondo si è utilizzato lo stesso procedimento ma il tutto viene implementato in un process.

Viene utilizzata la seconda soluzione perché occupa meno spazio, dato che le operazioni di shifting consistono semplicemente, nel caso dello shifting a destra prendere i sedici bit più significativi dal risultato della moltiplicazione, quando si shifta a sinistra basta accodare sedici zeri per avere lo stesso risultato della prima soluzione.

Il circito viene così descritto poiché tale forma di hashing prevedere di moltiplicare il dato per un valore A il quale è un numero compreso tra 0 ed 1, di cui il denominatore è un multiplo di due, per tale ragione di è scelto di moltiplicare per un valore W ed infine di shiftare a destra un numero di volte pari al valore dell' esponente, tale numero è la parte decimale del valore del dato per W (perché quando shiftiamo inseriamo degli zero fittizzi), dopodichè si effettua uno shifting a sinistra di un numero pari di volte affinché la nostra parte deciamale rientri nella parte del registro da inviare.

#### 17.2.1.2 Esponenziatore

Per effettuare l'elevazione a potenza con il modulo, ci siamo riferiti a questo algoritmo:

```
\begin{array}{l} \underline{\mathsf{Modular}\text{-}\mathsf{Exponentiation}} \ (\mathsf{a},\mathsf{b},\mathsf{n}) \\ \mathsf{c} \leftarrow \emptyset \\ \mathsf{d} \leftarrow 1 \\ \mathsf{for} \ \mathsf{i} \leftarrow \mathsf{k} \ \mathsf{downto} \ \emptyset \\ \mathsf{do} \ \mathsf{c} \leftarrow 2\mathsf{c} \\ \mathsf{d} \leftarrow (\mathsf{d}\text{-}\mathsf{d}) \ \mathsf{mod} \ \mathsf{n} \\ \mathsf{if} \ \mathsf{b}_{\mathsf{i}} = 1 \\ \mathsf{then} \ \mathsf{c} \leftarrow \mathsf{c} + 1 \\ \mathsf{d} \leftarrow (\mathsf{d}\text{-}\mathsf{a}) \ \mathsf{mod} \ \mathsf{n} \\ \mathsf{return} \ \mathsf{d} \end{array}
```

Figura 17.2: Algoritmo per modular exponentiational di un messaggio

L'algoritmo cicla sul numero di bit dell'esponente, moltiplica il valore d prima per se stesso e ne fa il modulo, questo stesso valore di d per la base quando il valore dell'esponente in forma binaria assume valore uno e ne effettua il modulo, (il parametro c non occorre per il calcolo del valore finale, occorre solo a capire in realtà alla fine se il numero è stato elevato per il corretto esponente).



Figura 17.3: Hardware Exponentiational

Utiliziamo questo algoritmo perché ci permette di riutilizzare componenti già sviluppati negli esercizi precedenti, difatti osservando lo schematico, vi è presente un moltiplicatore di Booth e il divisore restoring per le varie operazioni prodotto e modulo, un contatore down per indicare quale dei bit dell' esponente dobbiamo analizzare e dei selettori descritti con il costrutto with select per selezionare quali valori devono essere moltiplicati. La macchina a stati finiti non fa altro che eseguire i vari passi dell' algoritmo, però per problemi relativi al timing è stata realizzata alla fine con un singolo process, difatti una prima realizzazione con due process determinava che alcuni registri contenti i dati dell' operazione assumessero un valore indefinito (veniva sintetizzata un macchina che doveva avere una frequenza di clock minore da quella generabile dalla scheda).

Per problemi di spazio, si è ricorsi a componenti per la moltiplicazione e divisione seriali, oltre ad riutilizzarli all' interno dello stesso progetto difatti il moltiplicatore di Booth è stato utilizzato per: calcolare il prodotto di pq ed l' esponenziazione.

#### 17.2.2 Codice

RSA ISE

## 17.3 Simulazione

| Name            | Value           | 100,999,994 ps | 100,999,995 ps | 100,999,996 ps | 100,999,997 ps | 100,999,998 ps | 100,999,999 ps | 101. |
|-----------------|-----------------|----------------|----------------|----------------|----------------|----------------|----------------|------|
| 튢 clk           | 0               |                |                |                |                |                |                |      |
| 튢 start         | 0               |                |                |                |                |                |                |      |
| 튢 reset         | 1               |                |                |                |                |                |                |      |
| ≽ 😽 p[7:0]      | 00000011        |                |                | 0000001        |                |                |                |      |
| ≻ 😽 q[7:0]      | 00001011        |                |                | 0000101        |                |                |                |      |
| 🕨 😽 msg[7:0]    | 10000000        |                |                | 1000000        | 0              |                |                | ·    |
| ≻ 😽 e[15:0]     | 000000000000000 |                |                | 00000000000    | 00111          |                |                | į.   |
| ≻ 🌃 d[15:0]     | 000000000000000 |                |                | 00000000000    | 00011          |                |                | ĺ    |
| Correct[0:0]    | 1               |                |                | 1              |                |                |                |      |
| ▶ 🌄 msg_r[15:0] | 000000000000000 |                |                | 00000000000    | 00010          |                |                | į.   |

Figura 17.4: Esempio di computazione dei dati in cui il messaggio ricevuto ed inviato non coincidono

## 17.4 Sintesi su board FPGA

Valgono le stesse considerazione per il riconoscitore di stringhe 7.4, dove l'accensione del led zero indica che il messaggio ricevuto è diverso da quello di cui si è effettuato l'hashing, infatti se il messaggio è corretto tale led non viene abilitato. Dato il numero maggiore di dati in input i registri da caricare sono in numero superiore difatti viene accesso anche il led cinque per indicare quale registro si sta caricando, il caricamento del messaggio avviene quando led cinque e sei sono alti, si utilizza il display come descritto qui 8.4 e viene mostrata la versione firmata del messaggio inviato, il circuito che effettua la firma viene resettato quando i led sette e sei sono accesi.

